本文主要介绍怎么在Thinkphp中集成后台前端脚手架框架Vue-Cli。
一.安装Vue-Cli到Thinkphp中
1.1.1 检查是否安装node
终端输入npm的指令如果没有安装的话会提示未找到指令
data:image/s3,"s3://crabby-images/9f17b/9f17b1f90428cf0e4ae564684058fdd1fdc33f78" alt=""
正确的姿势如下图,说明已经安装了node依赖
data:image/s3,"s3://crabby-images/725d5/725d547114e6a13743cf0979fed9ea2f4d09eeb5" alt=""
1.1.2 安装node
到node的官网地址进行下载并安装步骤安装 node 安装地址:http://nodejs.cn/download/
注 :安装 vue-cli 脚手架目前需要node版本为 v4.0 以上
1.2 全局安装vue-cli
命令行执行 : npm install -g vue-cli 加-g是安装到全局,有时会安装失败如下图:
data:image/s3,"s3://crabby-images/1f9a7/1f9a76d668191f6e421e4cfa8841f4c16540f66c" alt=""
安装失败是因为权限不足,这时候使用sodo npm install -g vue-cli 进行管理员权限的安装即可,第一次安装需要输入管理员密码
data:image/s3,"s3://crabby-images/d4b4a/d4b4a8fd96c77dd8a51ef0da93f01c88b8ffc5e5" alt=""
安装完成检查一下vue的版本已确认vue安装完毕
data:image/s3,"s3://crabby-images/9ccf2/9ccf251fc016c3045a2afe60d1243d9c1c67c9b9" alt=""
1.3 在Thinkphp中安装vue
1.3.1 首先进入需要安装vue-cli的具体路径, 我的工程目录为:
data:image/s3,"s3://crabby-images/1a2b6/1a2b61429ad3dae6b55c2670e71114c429e79d40" alt=""
1.3.2 执行命令: vue init webpack Mob(你新建的项目名称/文件名称)执行之后将会 自动初始化一个文件夹 :Mob
data:image/s3,"s3://crabby-images/54859/548599d9c3879aa52cba096cc44845e3fe4bc2e4" alt=""
1.3.3 分别输入下列命令,会在8080端口开启一个网页服务
image
data:image/s3,"s3://crabby-images/42c01/42c01b822fa6d8b6c735e76ec5869c5588efcaea" alt=""
接下来我们访问http://localhost:8080就会出现vue的欢迎主页了
data:image/s3,"s3://crabby-images/87716/87716f71886d3107699e800277734282fdca639c" alt=""
如果观察路由便会发现其指向了HelloWorld组件并展示,这也就说明vue-cli脚手架安装完成了
data:image/s3,"s3://crabby-images/44562/44562b0967b70d6f86c6af45ac009aa0157721e6" alt=""
二.在Thinkphp后台管理系统中使用vue
vue-cli为我们创建后台管理系统页面提供了很好的方案,为了能够很好的和php代码进行解耦 我们可以把vue-cli的入口封装成一个模块组件,也就是我们经常在后台管理系统中具体的内容管理部分。下面是具体的实现步骤:
2.1 首先我们在admin模块中创建一个service控制器,我们把service控制器当成是后台管理系统的服务模块。在这个控制器中我们创建一系列的菜单模块并跳转至同一主页实现接口的统一。
data:image/s3,"s3://crabby-images/f2d4d/f2d4d8fbe4f5942c2d53343f2151ca0ce63100df" alt=""
2.2 书写service的入口文件index.html 并将打包好的vue单页进行引入
data:image/s3,"s3://crabby-images/e6f20/e6f202c9e9e8f4e2482a09c46aacaef3f0f41f8e" alt=""
2.3 在router的index.js中配置路由
data:image/s3,"s3://crabby-images/31a15/31a153e960beff6d2db7c27c0acfd94a28fcfc24" alt=""
2.4 因为默认的vue单页打包的页面文件名会添加哈希后缀,为了统一引入方便我们在webpack.prod.conf.js中修改配置文件将哈希后缀删除
data:image/s3,"s3://crabby-images/ce478/ce47888192e5a78e5584dbf972937ad840a22f48" alt=""
2.5 在终端输入npm run build 进行打包编译,因为之前我们添加了插件eslint,进行了代码格式检查所以会出现大量的警告,可以在webpack.base.conf.js中隐藏eslint的校验。
剔除校验前:
data:image/s3,"s3://crabby-images/c354a/c354a25bc815afe7367296074112ecd8c3cecfed" alt=""
修改配置文件:
data:image/s3,"s3://crabby-images/4211d/4211d75af4aa44d5c8e41d52ecd077f42a57b334" alt=""
再次编译后,便没有了警告:
data:image/s3,"s3://crabby-images/36a30/36a30944e7771f897a94d27e042500d56df74912" alt=""
2.6 打包完成后,发现在打包文件夹dist中多出了书写的两个单页
data:image/s3,"s3://crabby-images/b652c/b652c67e4b7e6247e120c71acd835100985a5267" alt=""
2.7 如果需要在本地进行预览调试则需要在service的index.html引入当前打包好的shopList和infoList单页
data:image/s3,"s3://crabby-images/94be7/94be74b706dcedeaba4bd704b0cb371970bd6cc2" alt=""
在vuePage.html中添加js
data:image/s3,"s3://crabby-images/848f3/848f348b03659f2f05baf66bfdd95ac257ec60d9" alt=""
2.8 终端输入npm run build 在浏览器中打开 http://localhost/admin/service/infoList#/infoList 这时候的页面结构是这样的,vue单页和php页面完全解耦,书写后台管理系统的时候我们只要关注vue单页区域就可以了,页面跳转和单页配置在php代码中完成即可。
data:image/s3,"s3://crabby-images/160ce/160ced8576bc6acb73b92c7b69cb39cf415eacc0" alt=""
2.9 主要的vue单页的书写可以不用每次都使用npm run build 进行打包.我们只要使用vue提供的8080端口就可以直接调试vue单页了 我们在浏览器打开 http://localhost:8080/admin/service/infoList#/infoList
data:image/s3,"s3://crabby-images/0de17/0de17d3a34e252ee587ad19388a8e90208bbae45" alt=""
网友评论