>PHP 프레임워크 >ThinkPHP >thinkphp에서 현재 페이지의 데이터를 수정하는 방법

thinkphp에서 현재 페이지의 데이터를 수정하는 방법

PHPz
PHPz원래의
2023-04-11 15:08:11684검색

ThinkPHP는 사용자 친화적인 개발 환경과 완전한 문서를 갖춘 탁월한 PHP 프레임워크입니다. ThinkPHP를 사용하면 매우 편리한 기능이 있습니다. 현재 페이지에서 데이터베이스의 데이터를 수정하는 것입니다. 구체적인 구현 방법을 소개하겠습니다.

먼저 ThinkPHP 프로젝트에서 데이터를 수정해야 하는 페이지를 찾으세요. 여기서는 index 메서드를 예로 들어 보겠습니다.

public function index()
{
    //查询数据
    $list = Db::name('test')->select();
    //将数据传递到模板
    $this->assign('list', $list);
    return $this->fetch();
}

위 코드는 테스트 테이블의 모든 데이터를 쿼리하고 쿼리 결과를 템플릿에 전달합니다. . 다음으로 템플릿의 데이터를 수정하는 버튼을 추가해야 합니다.

<table>
    <tr>
        <th>ID</th>
        <th>姓名</th>
        <th>年龄</th>
        <th>操作</th>
    </tr>
    {volist name='list' id='vo'}
    <tr>
        <td>{$vo.id}</td>
        <td>{$vo.name}</td>
        <td>{$vo.age}</td>
        <td><a href="{:url(&#39;edit&#39;, [&#39;id&#39;=>$vo.id])}">修改</a></td>
    </tr>
    {/volist}
</table>

위 코드는 페이지의 테스트 테이블에 있는 모든 데이터를 표시하고 각 행에 "수정" 버튼을 추가합니다. "수정" 버튼을 클릭하면 편집 방법으로 이동합니다:

public function edit($id)
{
    //根据ID查询数据
    $data = Db::name('test')->where('id', $id)->find();
    if(!$data) {
        $this->error('数据不存在');
    }
    //将数据传递到模板
    $this->assign('data', $data);
    return $this->fetch();
}

위 코드는 ID를 기반으로 테스트 테이블의 데이터 조각을 쿼리하고 쿼리 결과를 템플릿에 전달합니다. 그런 다음 템플릿에 양식을 추가하여 데이터를 수정합니다.

<form method="post" action="{:url(&#39;update&#39;)}">
    <input type="hidden" name="id" value="{$data.id}" />
    <div>
        <label>姓名</label>
        <input type="text" name="name" value="{$data.name}" />
    </div>
    <div>
        <label>年龄</label>
        <input type="text" name="age" value="{$data.age}" />
    </div>
    <button type="submit">提交修改</button>
</form>

위 코드는 수정할 데이터가 포함된 페이지에 양식을 표시합니다. 수정 사항을 제출한 후 데이터는 업데이트 메소드로 전송됩니다:

public function update()
{
    //接收表单提交的数据
    $id = input('post.id');
    $name = input('post.name');
    $age = input('post.age');
    //更新数据
    $update = Db::name('test')->where('id', $id)->update(['name'=>$name, 'age'=>$age]);
    if($update) {
        $this->success('修改成功');
    } else {
        $this->error('修改失败');
    }
}

위 코드는 양식에서 제출된 데이터를 기반으로 테스트 테이블의 데이터 조각을 업데이트하고 성공 또는 실패에 대한 프롬프트를 반환합니다. 가감.

요약하자면, 현재 페이지의 데이터베이스에 있는 데이터를 수정하려면 ThinkPHP를 사용하는 것이 매우 편리합니다. 페이지에 수정 버튼과 양식을 추가한 후 해당 메소드를 작성하면 됩니다.

위 내용은 thinkphp에서 현재 페이지의 데이터를 수정하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.