[TOC]
## 【编辑模型·思路分析】
> 编辑模型比较简单,最基本的增删改查操作
1、模板传入模型ID和选项卡ID
2、控制器判断,查询模型ID的指定信息,并分配给模板
3、模板编辑后,再提交给控制器保存处理
> 编辑模型,涉及两张表(模型表models记录信息;单独表名,如数据表test,修改成demo表)
## 【代码实现】
~~~
// 控制器代码
<?php
namespace app\admin\controller;
use think\Controller;
use think\Db;
use app\admin\model\Models as ModelsModel;
// 模型列表
public function index($tab = 1, $id = 0){
if (3 == $tab) {
$info = Db::name('models')->where('id',$id)->find();
if ($info != null && is_array($info)) {
$this->assign('info',$info);
}
}
}
// 编辑模型(控制器)
public function edit($tab=1,$id=0){
if(request()->isPost()){
//获取原数据库表名
$oldTableName = Db::name('models')->where('id',$id)->value('tablename');
//当前提前新表名
$newTableName = trim(input('post.tablename'));
$models = new ModelsModel;
if($models->allowField(true)->isUpdate()->save(input('post.'))){
//判断数据库表名是否做了修改
if($oldTableName!=$newTableName){
if($models->editTableName($oldTableName,$newTableName)){
return success('模型编辑成功!',url('index',['tab'=>1]));
}else{
return error('模型编辑失败!');
}
}else{
return success('模型编辑成功!',url('index',['tab'=>1]));
}
}else{
return error('模型信息未变动或修改失败!');
}
}
}
~~~
## 编辑独立数据表名(模型)
~~~
public function editTableName($oldTableName,$newTableName){
//获取数据表前缀
$dbPrefix = config('database.prefix');
Db::execute("RENAME TABLE `{$dbPrefix}{$oldTableName}` TO `{$dbPrefix}{$newTableName}` ;");
return true;
}
~~~
## 模板代码
~~~
<div id="tab-3" class="tab-pane {if condition="input('tab',1) eq 3"}active{/if}">
<div class="panel-body">
<form method="post" class="form-horizontal" action="{:url('edit')}" data-type="ajax">
<input type="hidden" name="tab" value="3" />
<input type="hidden" name="id" value="{$info.id}" />
<div class="form-group">
<label class="col-sm-2 control-label">数据表</label>
<div class="col-sm-10">
<input type="text" name="tablename" class="form-control" value="{$info.tablename}">
</div>
</div>
<!-- <div class="hr-line-dashed"></div> -->
<div class="form-group">
<label class="col-sm-2 control-label">模型名称</label>
<div class="col-sm-10">
<input type="text" name="name" class="form-control" value="{$info.name}">
</div>
</div>
<!-- <div class="hr-line-dashed"></div> -->
<div class="form-group">
<label class="col-sm-2 control-label">分类模板</label>
<div class="col-sm-10">
<select class="form-control m-b" name="category_template">
<option value="" >≡ 请选择模板 ≡</option>
{volist name="files" id="vo"}
<option value="{$vo.name}" {$vo.name == $info.category_template ? 'selected' : '' }>{$vo.name}</option>
{/volist}
</select>
</div>
</div>
<!-- <div class="hr-line-dashed"></div> -->
<div class="form-group">
<label class="col-sm-2 control-label">列表模板</label>
<div class="col-sm-10">
<select class="form-control m-b" name="list_template">
<option value="" selected>≡ 请选择模板 ≡</option>
{volist name="files" id="vo"}
<option value="{$vo.name}" {$vo.name == $info.list_template ? 'selected' : '' }>{$vo.name}</option>
{/volist}
</select>
</div>
</div>
<!-- <div class="hr-line-dashed"></div> -->
<div class="form-group">
<label class="col-sm-2 control-label">内容模板</label>
<div class="col-sm-10">
<select class="form-control m-b" name="show_template">
<option value="" selected>≡ 请选择模板 ≡</option>
{volist name="files" id="vo"}
<option value="{$vo.name}" {$vo.name == $info.show_template ? 'selected' : '' }>{$vo.name}</option>
{/volist}
</select>
</div>
</div>
<!-- <div class="hr-line-dashed"></div> -->
<div class="form-group">
<label class="col-sm-2 control-label">排序</label>
<div class="col-sm-10">
<input type="text" name="sort" class="form-control" value="{$info.sort}">
</div>
</div>
<div class="hr-line-dashed"></div>
<div class="form-group">
<div class="col-sm-4 col-sm-offset-2">
<button class="btn btn-primary" type="submit">提交</button>
</div>
</div>
</form>
</div>
</div>
</div>
~~~
- Layer无刷新不跳转弹框提示信息
- 整合ThinkPHP+实用代码
- TP整合Layer插件实现无刷新
- 自定义助手函数
- 添加信息失败后不跳转
- 三种无限级分类
- TP常用代码
- 自定义公共函数
- TP模型管理专题
- TP模型管理之添加模型
- sfox_newmodel.sql
- TP模型管理之删除模型
- TP模型管理之编辑模型
- TP模型管理之字段添加
- sfox_newmodel.sql_edit
- layer_hplus.js_edit
- TP模型管理之字段删除
- TP模型管理之字段编辑
- TP模型管理之预览模型
- TP模型管理之公共函数
- layer_hplus.js_修订一
- TP模型管理之预览模型静态页
- 后台内容管理系统
- 分类树显示
- 内容列表显示
- 信息发布
- 编辑信息
- layer_hplus.js
- myJs第一版
- myJs第二版
- myJs第三版
- myJs第四版
- TP5插件用法
- Datatables
- WebUploader
- bootstrap-fileinput
- UEditor
- 简单调用
- 路径问题
- 跨域多图上传
- 跨域单图上传
- UEditor图片跨域上传解决方案
- 定制工具栏图标
- ajaxFileUpload
- LayUI
- 图片上传
- layui分页
- 搜索页
- 搜索优化及删除
- Uploadify
- TP5前端应用
- 静态首页
- 前台首页功能实现
- 自定义标签库
- 前台模板继承应用
- 首页自定义标签改进
- 文章内容页
- 自定义标签改进
- 自定义标签修正
- 图片等比例自动缩放
- 后台权限管理
- 角色管理
- 规则管理
- 权限设置
- 会员管理
- 权限管理
- 前台登录注册功能
- 注册登录
- 阿里大于手机注册
- 阿里大于升级阿里云短信服务
- 自动登录完成
- PHP异位或加密实现自动登陆
- 微信开发
- 分享接口
- 静态页面实现微信分享
- 动态页微信分享
- 页面静态化
- 1-全站静态化前期配置
- 2-链接地址静态化
- TP5常用片段代码
- 加载静态资源路径与常量
- thinkphp5预定义常量
- 删除某文件夹的内容
- 解压插件包
- 异步提交插件
- 其他功能
- 背景音乐
- 手机访问PC网站自动跳转到手机网站代码
- 手机微信音乐MP3播放器
- 后盾之网页背景音乐
- 播放器宽度自适应
- 前台首页数据调用
- 视频列表
- 搜索分页
- H5解决苹果(IOS)不能自动播放音乐
- 清空缓存
- 文件处理常识
- 删除路径下的所有文件夹和文件
- 一键清空缓存
- 评论留言
- 格式化时间
- 替换微博内容的URL地址@用户与表情
- PHP正则理解
- jQuery评论插件
- TP空操作
- TP路由
- 跨域访问
- 设置请其头允许跨域请求
- 模板前台判断手机访问跳转手机网址代码
- PHP遍历一个文件夹下所有文件和子文件夹
- PHP获取视频的第一帧与时长
- TP5数据库
- 链式操作原理
- update替换字段部分内容
- 后台开发
- 后台登录页居中显示
- TP5自带验证码
- JS & JQuery专题
- 二级城市联动菜单
- 模板引擎
- 混合模板编译
- 黄永成TP微博开发
- 消息推送
- memcache安装
- 插件开发
- 插件介绍
- 插件钩子
- 浅谈初步理解钩子
- 插件钩子(hooks)分析
- 插件钩子简单理解
- 控制器调用插件
- 钩子通用处理函数
- 插件基类代码
- 插件测试代码
- 浅谈钩子与插件
- 技术综合
- 常用代码
- PHP
- 56个PHP开发常用代码片段(上)
- 56个PHP 开发常用代码片段(中)
- 56个PHP 开发常用代码片段(下)
- sublime text安装自动补全注释的插件
- 影音视频开发
- 视频
- H5视频直播扫盲
- 音乐
- 语音
- PHP实现语音播报功能
- MUI
- 窗体操作