1. 官方文檔地址:
? ThinkPHP6.0:[http://www.hmoore.net/manual/thinkphp6\_0/1037479](http://www.hmoore.net/manual/thinkphp6_0/1037479)
? ElemetUI:[https://element.eleme.cn/#/zh-CN](https://element.eleme.cn/#/zh-CN)
? axios:[http://www.hmoore.net/yunye/axios/234845](http://www.hmoore.net/yunye/axios/234845)
? Vue:[https://cn.vuejs.org/v2/guide](https://cn.vuejs.org/v2/guide)
2. 創建碼云倉庫
3. 克隆到本地
~~~linux
git clone 你自己的倉庫地址 0608
~~~
4. 創建數據庫
~~~sql
-- 創建數據庫 0608
create database `0608` charset utf8;
-- 創建數據表 user
create table `user` (
`id` int(11) primary key auto_increment comment '用戶ID',
`name` varchar(30) not null default '未知' comment '用戶名',
`pwd` varchar(32) not null default '未知' comment '用戶密碼'
) engine = InnoDB;
-- 給 user.name 添加唯一索引
alter table `user` add unique key u_name(`name`);
-- 給 user.pwd 添加普通索引
alter table `user` add index u_pwd(`pwd`);
-- 創建數據表 school
create table `school` (
`id` int(11) primary key auto_increment comment '學校ID',
`name` varchar(30) not null default '未知' comment '學校名',
`city` varchar(30) not null default '未知' comment '學校城市',
`num` varchar(30) not null default '0' comment '學校人數'
) engine = InnoDB;
~~~
5. 進入項目
~~~linux
cd 0608
~~~
6. 安裝ThinkPHP6.0
~~~linux
composer create-project topthink/think php
~~~
7. 配置域名/URL重寫
~~~nginx
# 自行去配置域名
# url 重寫
location / {
# 省略部分代碼
if (!-e $request_filename) {
rewrite ^(.*)$ /index.php?s=/$1 last;
}
}
~~~
8. 修改配置文件 .env 【來源于項目中的 .example.env】
~~~php
APP_DEBUG = true
[APP]
DEFAULT_TIMEZONE = Asia/Shanghai
[DATABASE]
TYPE = mysql
HOSTNAME = 127.0.0.1
DATABASE = 0608
USERNAME = root
PASSWORD = root
HOSTPORT = 3306
CHARSET = utf8
DEBUG = true
[LANG]
default_lang = zh-cn
~~~
9. 開啟錯誤調試模式
~~~php
// 1 .env 文件中第 1 行
APP_DEBUG = true
// 2 config/app.php 中第 33 行
'show_error_msg' => true
~~~
10. 初始化vue
查看node、npm、cnpm、vue-cli是否安裝成功
~~~js
// 查看 node 版本
node -v
// 查看 npm 版本
npm -v
// 查看 cnpm 版本
cnpm -v
// 查看 vue 版本
vue -V
// 初始化項目
vue init webpack vue
~~~
11. 進入vue進行測試、查看是否安裝成功
~~~js
// 進入 vue 項目中
cd vue
// npm 啟動項目
npm run dev
~~~
12. 安裝 Element-UI、axios
~~~js
// 安裝 ElementUI
cnpm install element-ui --save
// 安裝 axios
cnpm install axios --save
~~~
13. 在 vue/src/main.js 中增加以下內容
~~~js
// 引入 elementUI
// https://element.eleme.cn/#/zh-CN/component/quickstart
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI);
// 引入 axios
// https://segmentfault.com/a/1190000013128858
import axios from 'axios'
Vue.prototype.$ajax = axios
~~~
14. 將初始化好的項目提交到遠程倉庫
~~~js
// 進入項目中
cd 0608
// 查看狀態【紅色、提示使用 git add 】
git status
// 添加代碼到倉庫
git add ./
// 查看狀態【綠色、Changes to be committed:】
git status
// 提交代碼到本地倉庫
git commit -m '提交注釋'
// 查看狀態
git status
// 將遠程倉庫的更新拉取到本地
git pull
// 查看狀態
git status
// 將本地的更新提交到遠程倉庫
git push
~~~
15. 添加資源控制器/模型層/資源路由
~~~php
// 使用命令行:創建資源控制器
php think make:controller School
// 使用命令行:創建模型
php think make:model School
// 添加資源路由 php/route/app.php
// 跨域請求【路由->跨域請求】
Route::resource('school', 'School')->allowCrossDomain();
~~~
16. 編輯 curd 接口 - 控制器 - School.php
~~~php
<?php
declare(strict_types=1);
namespace app\controller;
use app\model\School as ModelSchool;
use think\facade\Validate;
use think\Request;
class School
{
/**
* 顯示資源列表
* 【get】http://0608.cc/school
* 【get】http://0608.cc/school?page=2
*
* @return \think\Response
*/
public function index(ModelSchool $school)
{
$pageSize = 3;
$res = $school->getPage($pageSize);
if ($res) {
return json(['code' => 0, 'msg' => 'ok', 'res' => $res]);
} else {
return json(['code' => 1, 'msg' => 'no', 'res' => null]);
}
}
/**
* 顯示創建資源表單頁.
*
* @return \think\Response
*/
public function create()
{
//
}
/**
* 保存新建的資源
* 【post】http://0608.cc/school?name=shbw&city=&num=10000
*
* @param \think\Request $request
* @return \think\Response
*/
public function save(Request $request, ModelSchool $school)
{
// 接收數據
$data['name'] = $request->param('name', '');
$data['city'] = $request->param('city', '');
$data['num'] = $request->param('num', '0');
// 數據驗證
$rule = [
'name' => 'require|max:30|min:2',
'city' => 'require',
'num' => 'require'
];
$message = [
'name.require' => '學校名稱是必填項',
'name.max' => '學校名稱最多30位',
'name.min' => '學校名稱最少2位',
'city.require' => '學校所在城市是必填項',
'num.require' => '學校現有人數是必填項'
];
// 粘貼來自于手冊:驗證->驗證規則->方法定義
$validate = Validate::rule($rule)->message($message);
if (!$validate->check($data)) {
return json(['code' => 1, 'msg' => $validate->getError(), 'res' => null]);
}
// 調用模型
$res = $school->addOne($data);
if ($res) {
return json(['code' => 0, 'msg' => '添加成功', 'res' => $res]);
} else {
return json(['code' => 1, 'msg' => '添加失敗', 'res' => $res]);
}
}
/**
* 顯示指定的資源
* 【get】http://0608.cc/school/3
*
* @param int $id
* @return \think\Response
*/
public function read($id, ModelSchool $school )
{
$where['id'] = $id;
$res = $school->selOne($where);
if ($res) {
return json(['code' => 0, 'msg' => '查詢成功', 'res' => $res]);
} else {
return json(['code' => 1, 'msg' => '查詢失敗', 'res' => $res]);
}
}
/**
* 顯示編輯資源表單頁.
*
* @param int $id
* @return \think\Response
*/
public function edit($id)
{
//
}
/**
* 保存更新的資源
* 【put】http://0608.cc/school/3?name=bjbw3&city=bj3&num=30000
*
* @param \think\Request $request
* @param int $id
* @return \think\Response
*/
public function update(Request $request, $id, ModelSchool $school)
{
// 接收數據
$where['id'] = $id;
$data['name'] = $request->param('name', '');
$data['city'] = $request->param('city', '');
$data['num'] = $request->param('num', '0');
// 數據驗證
$rule = [
'name' => 'require|max:30|min:2',
'city' => 'require',
'num' => 'require'
];
$message = [
'name.require' => '學校名稱是必填項',
'name.max' => '學校名稱最多30位',
'name.min' => '學校名稱最少2位',
'city.require' => '學校所在城市是必填項',
'num.require' => '學校現有人數是必填項'
];
// 粘貼來自于手冊:驗證->驗證規則->方法定義
$validate = Validate::rule($rule)->message($message);
if (!$validate->check($data)) {
return json(['code' => 1, 'msg' => $validate->getError(), 'res' => null]);
}
// 調用模型
$res = $school->updOne($where, $data);
if ($res) {
return json(['code' => 0, 'msg' => '修改成功', 'res' => $res]);
} else {
return json(['code' => 1, 'msg' => '修改失敗', 'res' => $res]);
}
}
/**
* 刪除指定資源
* 【delete】http://0608.cc/school/1
*
* @param int $id
* @return \think\Response
*/
public function delete($id, ModelSchool $school)
{
$where['id'] = $id;
$res = $school->delOne($where);
if ($res) {
return json(['code' => 0, 'msg' => '刪除成功', 'res' => $res]);
} else {
return json(['code' => 1, 'msg' => '刪除失敗', 'res' => $res]);
}
}
}
~~~
17. 編輯 curd 接口 - 模型層 - School.php
~~~php
<?php
declare (strict_types = 1);
namespace app\model;
use think\Model;
/**
* @mixin think\Model
*/
class School extends Model
{
protected $table = 'school';
protected $pk = 'id';
// 設置字段信息
protected $schema = [
'id' => 'int',
'name' => 'string',
'city' => 'string',
'num' => 'string'
];
/**
* 分頁
*/
public function getPage( $pageSize)
{
return self::paginate( $pageSize );
}
/**
* 添加一條數據
*/
public function addOne($data)
{
return self::insert( $data );
}
/**
* 刪除數據
*/
public function delOne($where)
{
return self::where( $where )->delete();
}
/**
* 修改
*/
public function updOne($where,$data)
{
return self::where( $where )->update( $data );
}
/**
* 查詢一條
*/
public function selOne($where)
{
return self::where( $where )->find();
}
}
~~~
18. 使用Postman測試 curd 接口
~~~php
# 展示/分頁 get
http://0608.cc/school
http://0608.cc/school?page=2
# 添加 post
http://0608.cc/school?name=shbw&city=&num=10000
# 根據 ID 查詢一個 get
http://0608.cc/school/3
# 修改 put
http://0608.cc/school/3?name=shbw&city=&num=10000
# 刪除 delete
http://0608.cc/school/1
~~~
19. Vue中添加路由/頁面
~~~js
// 在 vue/src/ 中增加 page/school/{ list.vue,add.vue }
// 增加路由 vue/router/index.js
import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
// 導入登錄頁面
import login from '@/page/main/login.vue'
// 導入以下頁面
import schoolList from '@/page/school/list.vue'
import schoolAdd from '@/page/school/add.vue'
import schoolEdit from '@/page/school/edit.vue'
Vue.use(Router)
export default new Router({
routes: [{
path: '/',
name: 'HelloWorld',
component: HelloWorld
},
{
path: '/login',
name: 'login',
component: login
},
{
path: '/schoolList',
name: 'schoolList',
component: schoolList
},
{
path: '/schoolAdd',
name: 'schoolAdd',
component: schoolAdd
},
{
path: '/schoolEdit',
name: 'schoolEdit',
component: schoolEdit
}
]
})
~~~
20. 展示頁面 - list.vue
~~~vue
<template>
<div>
<a href="/#/schoolAdd"><el-button type="button" size="small" style="float: left;">數據添加</el-button></a>
<!-- 展示表格 start https://element.eleme.cn/#/zh-CN/component/table -->
<el-table :data="tableData" stripe style="width: 100%">
<el-table-column prop="id" label="ID" width="150"></el-table-column>
<el-table-column prop="name" label="學校名" width="150"></el-table-column>
<el-table-column prop="city" label="所在城市" width="150"></el-table-column>
<el-table-column prop="num" label="人數" width="150"></el-table-column>
<el-table-column label="操作">
<template slot-scope="scope">
<el-button @click.native.prevent="deleteRow(scope.row)" type="text" size="small">刪除</el-button>
<el-button @click.native.prevent="editRow(scope.row)" type="text" size="small">編輯</el-button>
</template>
</el-table-column>
</el-table>
<!-- 展示表格 end -->
<!-- 分頁控件 start https://element.eleme.cn/#/zh-CN/component/pagination -->
<el-pagination background layout="prev, pager, next" :total="total" :page-size="pageSize" @current-change="getCurrentPage"></el-pagination>
<!-- 分頁控件 end -->
</div>
</template>
<script>
export default {
data() {
return {
tableData: [],
currentPage: 1,
total: 0,
pageSize: 3
};
},
created() {
var _self = this;
_self.getPage();
},
methods: {
// 調用接口、獲取分頁數據
getPage: function() {
var _self = this;
// 使用 ajax 請求后臺提供的展示接口
_self.$ajax
.get('http://0608.cc/school', {
params: {
page: _self.currentPage
}
})
.then(function(response) {
_self.tableData = response.data.res.data;
_self.total = response.data.res.total;
})
.catch(function(error) {
console.log(error);
});
},
//當前頁改變事件
getCurrentPage: function(page) {
var _self = this;
// 改變當前頁碼
_self.currentPage = page;
// 獲取當前頁數據
_self.getPage();
},
// 刪除一條數據
deleteRow(data) {
var _self = this;
var id = data.id;
_self.$ajax
.delete('http://0608.cc/school/' + id)
.then(function(response) {
alert(response.data.msg);
if (response.data.code == 0) {
_self.getPage();
}
})
.catch(function(error) {
console.log(error);
});
},
// 編輯
editRow(row) {
this.$router.push({ name: 'schoolEdit', params: row });
}
}
};
</script>
<style></style>
~~~
21. 添加頁面 - add.vue
~~~vue
<template>
<div>
<a href="/#/schoolList"><el-button type="button" size="small" style="float: left;">數據列表</el-button></a>
<br />
<br />
<!-- 表單 start https://element.eleme.cn/#/zh-CN/component/form -->
<el-form :model="dataForm" status-icon ref="dataForm" label-width="100px" class="">
<el-form-item label="學校名稱" prop="name"><el-input type="text" v-model="dataForm.name"></el-input></el-form-item>
<el-form-item label="所在城市" prop="city"><el-input type="text" v-model="dataForm.city"></el-input></el-form-item>
<el-form-item label="人數" prop="num"><el-input type="number" v-model.number="dataForm.num"></el-input></el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm()">提交</el-button>
<el-button @click="resetForm('dataForm')">重置</el-button>
</el-form-item>
</el-form>
<!-- 表單 end -->
</div>
</template>
<script>
export default {
data() {
return {
dataForm: {
name: '',
city: '',
num: ''
}
};
},
methods: {
submitForm() {
var _self = this;
_self.$ajax
.post('http://0608.cc/school', _self.dataForm)
.then(function(response) {
// 不管成功與失敗、都彈出消息
alert(response.data.msg);
// 判斷是否成功、成功跳轉至展示頁面
if (response.data.code == 0) {
_self.$router.push({ name: 'schoolList' });
}
})
.catch(function(error) {
console.log(error);
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
}
}
};
</script>
<style></style>
~~~
22. 修改頁面
~~~vue
<template>
<div>
<a href="/#/schoolList"><el-button type="button" size="small" style="float: left;">數據列表</el-button></a>
<br />
<br />
<!-- 表單 start https://element.eleme.cn/#/zh-CN/component/form -->
<el-form :model="dataForm" status-icon ref="dataForm" label-width="100px" class="">
<el-form-item label="學校名稱" prop="name"><el-input type="text" v-model="dataForm.name"></el-input></el-form-item>
<el-form-item label="所在城市" prop="city"><el-input type="text" v-model="dataForm.city"></el-input></el-form-item>
<el-form-item label="人數" prop="num"><el-input type="number" v-model.number="dataForm.num"></el-input></el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm()">提交</el-button>
<el-button @click="resetForm('dataForm')">重置</el-button>
</el-form-item>
</el-form>
<!-- 表單 end -->
</div>
</template>
<script>
export default {
data() {
return {
dataId: this.$route.params.id,
dataForm: {
name: this.$route.params.name,
city: this.$route.params.city,
num: this.$route.params.num
}
};
},
methods: {
submitForm() {
var _self = this;
_self.$ajax
.put('http://0608.cc/school/' + _self.dataId, _self.dataForm)
.then(function(response) {
// 不管成功與失敗、都彈出消息
alert(response.data.msg);
// 判斷是否成功、成功跳轉至展示頁面
if (response.data.code == 0) {
_self.$router.push({ name: 'schoolList' });
}
})
.catch(function(error) {
console.log(error);
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
}
}
};
</script>
<style></style>
~~~
23. 登錄頁面
~~~vue
<template>
<div>
<!-- 表單 start https://element.eleme.cn/#/zh-CN/component/form -->
<el-form :model="dataForm" status-icon ref="dataForm" label-width="100px" class="">
<el-form-item label="用戶名" prop="name"><el-input type="text" v-model="dataForm.name"></el-input></el-form-item>
<el-form-item label="密碼" prop="pwd"><el-input type="password" v-model="dataForm.pwd"></el-input></el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm()">登錄</el-button>
<el-button @click="resetForm('dataForm')">重置</el-button>
</el-form-item>
</el-form>
<!-- 表單 end -->
</div>
</template>
<script>
export default {
data() {
return {
dataForm: {
name: '',
pwd: ''
}
};
},
methods: {
submitForm() {
var _self = this;
_self.$ajax
.get('http://0608.cc/login', { params: _self.dataForm })
.then(function(response) {
// 不管成功與失敗、都彈出消息
alert(response.data.msg);
// 判斷是否成功、成功跳轉至展示頁面
if (response.data.code == 0) {
_self.$router.push({ name: 'schoolList' });
}
})
.catch(function(error) {
console.log(error);
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
}
}
};
</script>
<style></style>
~~~
24. 完工!!
25. 聲明本人博客的所有東西,部分源于網絡書籍和視頻,其他的是個人的理解感悟,經過自己整理撰寫成博客。本人博客均只用于個人學習、復習,不作為商業用途,如有侵權,請聯系我修改或刪除。聯系郵箱:itlaowen@163.com
26. https://www.cnblogs.com/laowenBlog/p/13066263.html
- 空白目錄
- thinkcmf的權限管理
- thinkcmf+unicmf添加頁面
- Thinkphp5做后臺 Uni-app做前臺解決跨域問題
- 組件
- h5跨域-uniapp
- thinkphp5 auth 教程
- thinkphp5Auth類
- uniapp添加與編輯的差別
- 常見的請求方式
- uni 單選回顯數據_uniapp 頁面跳轉傳值和接收
- uni-app 單選/多選/滑動 demo
- 關于uniapp checkbox多選框如何傳值傳數據
- uniApp 多選框checkbox ,判斷是否選中
- uniapp添加復選框和獲取復選框的值
- uni-app中全選多選單選
- uniapp多選框CheckBox 數據接收
- uniapp下拉列表單選框復選框實戰demo(編輯或詳情頁)
- uni-data-CheckBox-OK
- js 字符串數組轉換成數字數組
- js把字符串轉為數組對象
- js中數組對象字符串的相互轉換
- JS怎么把字符串數組轉換成整型數組
- 小程序開發
- tp5.1跨域請求
- uniapp-h5跨域
- 新增
- order
- uni-app中調取接口的三種方式與封裝uni.request()
- uView-checkbox
- 給u-view的u-select賦值
- uView-下拉框、復選框、單選框 數據發送及接收
- CURD操作
- thinkphp5.1增刪改查
- TP5.1添加數據成功之后返回自增主鍵id
- Thinkphp實戰之Request默認值except only 以及過濾參
- uni-app跨域解決方案
- thinkphp5.1+uni-app接口開發中跨域問題解決方案
- tp6 + uniapp 前后端跨域解決方案
- uniapp-token相關
- uniapp request請求封裝包含token兼容多端,簡單易用
- CORS.php
- ThinkPHP6 API開發前后端分離用戶信息保存在后端的方法
- thinkphp的jwt(JSON Web Token)身份驗證
- thinkphp6增刪改查
- PHP模擬GET,POST請求
- php模擬get、post發送請求的6種方法
- thinkphp6
- uniapp封裝網絡請求
- thinkphp6搭建后端api接口jwt-auth
- uniapp實現APP微信登錄流程
- [uni-app] 中保持用戶登錄狀態
- 詳解vue中localStorage的使用方法
- vue 實現通過vuex 存儲值 在不同界面使用
- dispatch:異步操作,數據提交至 actions ,可用于向后臺提交數據
- ThinkPHP6.0 + Vue + ElementUI + axios 的環境安裝到實現 CURD 操作
- tp6錯誤集
- TP6 模型插入/添加數據,自動插入時間(自動時間戳)
- 手機不開機維修思路
- thinkphp6解決vue跨域問題
- 從0基礎獲取短視頻去水印解析接口制作
- thinkphp5 刪除緩存
- thinkPHP,怎么把json文件里面的數據導入數據庫
- 數字轉字符php
- php – 直接用curl下載遠程文件
- thinkphp – 直接用curl下載遠程文件
- apiAdmin安裝
- echart
- thinkphp開發小程序推廣分享帶參數二維碼生成
- php同比增加函數
- PHP獲取同比上周、上一個月,上一個季度,去年時間區間
- “前3秒”金句100例,趕緊收藏起來!
- PHP配合微信公眾號生成推廣二維碼
- thinkphp5+php微信公眾號二維碼掃碼關注推廣二維碼事件實現
- 獲取當前時間上一周的開始時間和結束時間
- TP6 查找指定工作日
- PHP 獲取當天、近一周、本周、上月、本月、本季度、上季度時間方法大全
- php獲取今日、昨日、本周、本月 日期方法
- Tp5+mysql按年季度月周日小時查詢時無數據的時間段補0方法
- mysql按天統計的時候,該天沒有數據也要統計為0
- 列出一星期的日期 無數據補0
- thinkphp6本周 上周 周一 周末日期
- 補全日期 無數據補0
- php+pv統計代碼實現,Laravel 10 行代碼實現簡單的網站 pv uv 統計
- 通過API獲取ip地址以及城市和運營商
- 獲取訪客信息
- 13行代碼實現微信小程序設置概率觸發激勵視頻閱讀文章
- uniapp 微信小程序 獲取場景值和場景值個性化參數
- 微信小程序分享小程序碼的生成(帶參數)以及參數的獲取
- 小程序推廣分享帶參數二維碼生成
- uniapp微信小程序生成對應頁面二維碼
- uniapp獲取當前頁面url
- uniapp微信小程序--微信登錄
- 微信小程序,生成小程序碼中scene參數的存放和獲取問題
- uni-app 微信小程序生成二維碼帶參數
- uni-app 微信小程序如何把圖片保存到本地相冊?
- thinkPHP5使用assign()傳遞富文本,前端解析成HTML標簽
- tp6解析編輯器里面的html標簽原樣輸出
- PHP判斷url鏈接是否被百度收錄
- 微擎安裝模塊時提示 Failed to connect to we7.rewlkj.com port 80: Timed out
- 小程序碼生成
- thinkphp開發小程序推廣分享帶參數二維碼生成0
- tp3.2偽靜態
- apiadmin安裝教程-2022.8更新
- autojs事件代碼
- uuuu
- thinkphp6: API 多版本控制