关于vue 框架与后台框架的混合使用的尝试------转载
这几天我在研究前台框架和后台框架融合的问题,进行了一些尝试;
我前台选择的是 vue,当然也可以选择 react 等其他 mvvm 框架,不过 vue 对于我来说是最熟悉的;
后台话,我选择的是 php 的 lumen 框架,他是laravel 的简化版,因为比较轻量,所以这也是我的选择;
先说下我这边的环境:
系统:Mac os 10.12;
服务器:apache 2.2;
php:7.0;
lumen:5.4;
vue:2.0以上;
这是 lumen 的官网 https://lumen.laravel-china.org/docs/5.3
lumen 的下载和配置,官网里已经有了,我简单说下,首先要下载 composer, 可以用命令下载最新的版本,也可以直接取 github 上下载其他版本,不过这种方法下载完后要使用命令:
composer update //下载依赖
|
1
|
composer update |
直接用命令下载的话不需要;
记得 apache 开启重写
我这边的虚拟目录指向:
|
1
2
3
4
5
6
7
8
9
10
|
<virtualhost *:83> DocumentRoot "/Users/apple/Sites/lumen/blog/public" ServerName 127.0.0.1:80 <directory "/Users/apple/Sites/lumen/blog/public"> Options Indexes FollowSymLinks ExecCGI Order allow,deny Allow from all AllowOverride All </directory></virtualhost> |
配置好 lumen 之后;
cd 到 public文件夹;
下载 vue;
这边创建 vue 项目的时候有2种选择:
1.vue init webpack-simple projectName
这是没有 router的简化版; 在在路由文件或者控制器或视图中指向对映的html 资源;
2.vue init webpack projectName
这是完整的;
在资源指向的时候通过路由来调到对应的页面
我选择的是第二种
再就是三连发
|
1
2
3
|
cd projectNamenpm installnpm run dev |
可以看到浏览器跳出了一个页面正是 vue 成功的页面;
现在东西都已经下载好了
再就是配置;
那么在 apache 中该怎么访问 vue 的项目呢;
我在网络上找了很多方案,最终还是选择了生成静态文件来进行访问,也就是:
|
1
|
npm run build |
不过问题又来了, build 之后的修改并没有热加载;
那么在 apache 上能实现么?
我搜索了大半天,并没有发现什么能够实现的(也许是我还没发现);
现在解决的方案我想了一下 webpack 是 node 的,也只能在 npm 上热加载了(也许有其他的轮子能实现);
这里放下我的解决方案:
lumen 目录下的 /routes/web.php:
|
1
|
$app->get('index/{id}', 'UserController@show'); |
这里我添加了一个路由指向user 控制器下的 show 方法;
lumen 目录下的 /app/http/controllers/
新建的 UserController.php:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<?phpnamespace App\Http\Controllers;use App\User;use Illuminate\Http\Response;class UserController extends Controller{ public function show($id) { $content = view('hello',['message'=>'Hello LaravelAcademy']); $status = 200; $value = 'text/html;charset=utf-8'; return (new Response($content, $status)) ->header('Content-Type', $value); }} |
lumen目录下的/resources/views/
新建文件hello.blade.php:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<!DOCTYPE html><html><head> <title>demo</title></head><body><div>视图</div>{{$message}}{{include('Grewer/dist/index.html')}}</body></html> |
开启 apache;
在浏览器上输入 http://127.0.0.1:83/index/1
但是你会发现vue 的首页静态资源加载成功了
,其他文件加载缺失败了
这个时候需要对 vue 的 /config/index.js文件进行配置:
我这边是这样修改的
|
1
|
assetsPublicPath: '/Grewer/dist/' |
第一个路径为你的项目名称;
修改完后需要重新生成资源:
使用:
|
1
|
npm run build |
这样打开http://127.0.0.1:83/index/1

发现已经成功了;
在就是热加载的问题;
开发的话只能在 npm run dev 上的服务器进行(也许其他的也可以,请告诉我);
使用 npm run dev 启动页面:
在该页面上进行调试;
关于跨域的问题:
在 npm 上进行的ajax 调用的借口都是apache 服务器的所以在 vue 的 index.html 上先定义好路径,比如说:
|
1
2
3
|
var app = { root:'http://127.0.0.1:83/'} |
在 vue 页面调用接口的时候前缀就是 app.root+"index/1";
在 lumen 目录下的 /routes/web.php添加:
|
1
|
header("Access-Control-Allow-Origin:*"); |
我认为这是最简单的跨域解决跨域的方法;
现在的借口都能进行调用获得数据了,然后页面的话通过 vue 的router;
比如我在vue 项目中的/src/router/index.js 文件中新添加了一个路径
|
1
2
3
4
5
|
{ path: '/test', name: 'Hello', component: Hello }, |
与根目录指向同一个文件;
需要跳转的时候就跳转到这里:http://127.0.0.1:83/index/1#/test
在需要上线的时候就把 vue 目录下的 app.root 修改一下,再把路由中的允许跨域关掉;
再就是 npm run build;
lumen 框架的根目录可以直接指向 vue 的 index.html;
好了,这就是前台框架和后台的混合了;
写得不好或者粗浅还请见谅;
如果你有更好的方案或者轮子,可以告诉我;
我看到了 laravel 有 mix 可以使用 webpack,下次可以尝试一下
end;
关于vue 框架与后台框架的混合使用的尝试------转载的更多相关文章
- 关于vue 框架与后台框架的混合使用的尝试
这几天我在研究前台框架和后台框架融合的问题,进行了一些尝试; 我前台选择的是 vue,当然也可以选择 react 等其他 mvvm 框架,不过 vue 对于我来说是最熟悉的; 后台话,我选择的是 ph ...
- 神奇!这款 Vue 后台框架居然不用手动配置路由
前言 做 Vue 开发脱离不了路由,尤其是中大型项目,页面多且杂,在配置路由的时候总是会变得逐渐暴躁,因为费时,并且又没有什么太多技术含量,总觉得是在浪费时间. 另外如果接手了别人的项目,当业务有变更 ...
- VUE:渐进式JavaScript框架(小白自学)
VUE:渐进式JavaScript框架 一.官网 英文 https://vuejs.org/ 中文 https://cn.vuejs.org/ 二:渐进式 即有一个核心库,在需要的时候再逐渐添加插件的 ...
- 手把手教你使用Vue/React/Angular三大框架开发Pagination分页组件
DevUI是一支兼具设计视角和工程视角的团队,服务于华为云DevCloud平台和华为内部数个中后台系统,服务于设计师和前端工程师.官方网站:devui.designNg组件库:ng-devui(欢迎S ...
- 基于vite2+electron12后台管理模板|Electron后台框架系统
前一溜时间有给大家分享一个 electron+vite跨端短视频 项目.这次分享的是vite2.x和electron实现跨平台后台框架,支持国际化多语言配置.导航菜单+树形菜单两种路由菜单模式.展开/ ...
- 爆款预订,2022 年最值得关注的后台框架 —— Fantastic-admin
前言 如果 2021 年你还没有听说过 Fantastic-admin ,那即将到来的 2022 年可不要再错过了. Fantastic-admin 做为一款开箱即用的 Vue 中后台管理系统框架,距 ...
- EasyUI+MVC-搭建后台框架
一.EasyUI简介: jQuery EasyUI是一组基于jQuery的UI插件集合体,而jQuery EasyUI的目标就是帮助web开发者更轻松的打造出功能丰富并且美观的UI界面. 官方网站:h ...
- 推荐10个bootstrap及其他框架的后台管理模板
相对于网站前台炫目多彩的设计,网址后台的设计模板貌似有点少,在这里推荐10个可以免费下载的~ 1.自适应超酷整站 win8风格的Bootstrap响应式网站后台管理模板-Apricot 2.boots ...
- jquery easyui+layer后台框架
最近使用jquery easyui搭建了一个后台框架,以方便以后使用 上图先: 下载地址:CSDN下载
随机推荐
- bootstrap_table_class表格样式实例
<div class="container"> <h2>表格</h2> <!--table标签级别的样式说明如下: ----.table ...
- 快速排序Golang版本
Created by jinhan on --. Tip: http://blog.csdn.net/zhengqijun_/article/details/53038831 See: https:/ ...
- kafka原理和实践(二)spring-kafka简单实践
系列目录 kafka原理和实践(一)原理:10分钟入门 kafka原理和实践(二)spring-kafka简单实践 kafka原理和实践(三)spring-kafka生产者源码 kafka原理和实践( ...
- 安装memcached
简介 memcached是免费和开放源代码的高性能分布式内存对象缓存系统,旨在通过减轻数据库负载来加速动态Web应用程序.其有以下特点: 基于简单的文本行协议 全部数据按照k/v形式存放在内存中,无持 ...
- Android APP 性能优化的一些思考
说到 Android 系统手机,大部分人的印象是用了一段时间就变得有点卡顿,有些程序在运行期间莫名其妙的出现崩溃,打开系统文件夹一看,发现多了很多文件,然后用手机管家 APP 不断地进行清理优化 ,才 ...
- 当final作用于变量、参数、方法和类时该如何处理
final变量: 对于基本类型使用final:它就是一个常量,数值恒定不变 对于对象引用使用final:使得引用恒定不变,一旦引用被初始化指向一个对象,就无法再把 它改为指向另一个对象.然而,对象自身 ...
- mysql 打开慢查询日志
打开mysql的配置文件 my.ini或是my.cnf找到节点[mysqld]下添加下面这两行(默认可能不带这两行,直接手敲即可) [AppleScript] 纯文本查看 复制代码 ? 1 2 3 ...
- Hibernate框架进阶(中篇)之多表关系
导读 Hibernate进阶主要分为上中下三篇,本文是中篇,主要讲解Hibernate框架中多表关系的实现.我们知道多表关系有一对一.一对多(多对一)和多对多三种关系.而1对1关系一般合并为一个表处理 ...
- Qt 显示图片的三种方法
一. 直接用QLabel显示原图 //单独显示的QLabel 其大小为内容即图片的大小,若将QLabel放入QMainWindow中则QLabel的大小为其初始大小. /* QLabel *label ...
- uva 1378 - A Funny Stone Game(组合游戏)
题目链接:uva 1378 - A Funny Stone Game 题目大意:两个人玩游戏,对于一个序列,轮流操作.每次选中序列中的i,j,k三个位置要求i<j≤k,然后arr[i]减1,对应 ...