这种问题你需要把终端的报错信息贴出了我们才能帮你啊!!!!!!!
如果我们希望把数据显示到模板(template)中,使用最多的语法是 “Mustache”语法 (双大括号) 的文本插值。并且我们前端提到过,data返回的对象是有添加到Vue的响应式系统 中,当data中的数据发生改变时,对应的内容也会发生更新。当然,Mustache中不仅仅可以是data中的属性,也可以是一个JavaScript的表达式:下面这种写法是语句不是表达式,所以是错误的:v-once用于指定元素或者组件只渲染一次,当数据发生变化时,元素或者组件以及其所有的子元素将视为静态内容并且跳过,该指令可以用于性能优化。如果添加到父节点,那么所有的子节点也是只会渲染一次:用于更新元素的 textContent,等价于"Mustache"语法,而且"Mustache"语法更灵活。默认情况下,如果我们展示的内容本身是 html 的,那么vue并不会对其进行特殊的解析。如果我们希望这个内容被Vue可以解析出来,那么可以使用 v-html 来展示。v-pre用于跳过元素和它的子元素的编译过程,显示原始的Mustache标签。跳过不需要编译的节点,加快编译的速度。这个指令保持在元素上直到关联组件实例结束编译。v-cloak 和 CSS 规则如 [v-cloak] { display: none } 一起用时,这个指令可以隐藏未编译的 Mustache 标签直到组件实例准备完毕,主要用于解决闪动问题,现在Vue3一般不会出现这个问题了。
介绍:
这是一个用vuejs2.0和element搭建的后台管理界面。
相关技术:
vuejs2.0:渐进式JavaScript框架,易用、灵活、高效,似乎任何规模的应用都适用。
element:基于vuejs2.0的ui组件库。
vue-router:一般单页面应用spa都要用到的前端路由。
vuex:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。
Laravel 5 Boilerplate —— 基于当前Laravel最新版本(Laravel 5.1.*)并集成Boilerplate的项目
Laravel 5 Angular Material Starter —— 这是一个Laravel 5.1和AngularJS的原型项目
Someline Starter —— 基于Laravel 5和Vue.js,用于快速构架RESTful API和Web应用的原型项目
CMS
Bootstrap CMS —— Laravel 5.1驱动的功能强大的CMS
October —— 基于Laravel 5,致力于让开发工作变得简单的CMS
PyroCMS —— MVC架构的PHP内容管理系统,3.0以前基于CodeIgniter,目前基于Laravel 5.1
LavaLite —— 基于Laravel 5.1 & Bootstrap 3的内容管理系统
TypiCMS —— 基于 Laravel 5 构建的、支持多语言的内容管理系统
Laravel and AngularJS CMS —— 基于Laravel 5.1和AngularJS的CMS
Microweber —— 基于 Laravel 拖拽式生成 CMS 及在线商店利器
AsgardCMS —— 基于 Laravel 构建的、支持模块化和多语言的CMS
CRM
Flarepoint —— 基于Laravel构建的免费开源CRM平台
论坛
Laravel.io —— Laravel开发者社区
Flarum —— 免费的、开源的、专注于简约的论坛系统,esoTalk和FluexBB的联合继承者
PHPHub —— 基于Laravel 4.2,积极向上的 PHP & Laravel 开发者社区
电商
Antvel —— 基于 Laravel 5.* www.lonwin.net开发的开源电子商务项目
项目管理
92five app —— 基于 Laravel框架 & Backbone JS 构建,是一个自托管的、基于web的项目管理应用
Scrumwala —— 基于Laravel5,项目管理应用
博客
Canvas —— 基于Laravel 5.2 开发的轻量级博客系统
Katana —— 静态博客/站点生成器(支持Markdown和GitHub Pages)
Vuedo —— 基于 Laravel 和 Vue.js 构建的博客平台
Wardrobe —— 专注于写作的最小化博客平台
后台模板
Laravel Angular Admin —— 基于 Laravel + Angularjs + Bootstrap + AdminLTE 实现的后台模板
其他
Laravel.com —— Laravel官网源码
Laravel Tricks —— Laravel小技巧&小贴士
Invoice Ninja —— 基于Laravel构建的开源发票及时间跟踪应用
Paperwork —— 基于Laravel 4.X的开源的笔记&归档工具
Cachet —— 基于Laravel 5的开源的状态页系统
StyleCI —— 由 PHP CS Fixer开发,提供PHP代码风格持续集成服务
Podcastwala —— 基于Laravel 5,构建属于你自己的播客网站
Deployer —— 基于Laravel 5.1的、免费的、开源的PHP应用部署工具
RSS Monster —— 基于 Lumen 开发的 RSS 聚合器和阅读器
Koel —— 基于 Laravel 5.1 & Vue.js 开发的酷炫音乐流媒体应用
Attendize —— 基于 Laravel 框架开发的开源门票及活动管理应用
很多时候搭建好了环境,但是不知道怎么入手去开发。
下面我们通过简单案例说明如何快速入门开发模块:
例1:开发helloworld模块
搭建好环境,新建项目以后,进入项目所在文件夹,依次进入src/components,这里存放我们页面模板,进入src/router,编辑index.js,找到path: '/', 这里是路径也就是url访问的显示,当前默认的是根目录,也就是首页访问才会出现helloworld模块的内容,将path改为path: '/HelloWorld',通过url访问:8082/#/helloworld,出现了我们想要的结果。如图1:
图2 helloworld 效果图
开发步骤:

1)导入 import HelloWorld from '@/components/HelloWorld'
2)注册
{path: '/HelloWorld',name: 'HelloWorld',component: HelloWorld}
注意首字母大写,驼峰法命名;
例2:新闻列表
图2 文章列表效果图
News.vue代码:
<template> <div class="main"><h1>{{msg}}</h1><div ><ul><li v-for="(item,index) in list" :key="index"><router-link :to="{path: 'newsdetail', query: {id: item.id}}"> {{item.news_name}}</router-link></li></ul></div> </div></template><script>import axios from 'axios'export default { name: 'news', data () {return {artid: 19,msg: '这是新闻列表',list: [{'news_name': '新闻标题1', id: 1},{'news_name': '新闻标题2', id: 2},{'news_name': '新闻标题3', id: 3}]} }, mounted () {var that = thisaxios.post('/api/newslist', {parid: that.artid}).then(function (response) {that.list = response.data.list}) }}</script>
编辑src/router/index.js
第一步:导入 Newsimport News from '@/components/News'第二步:注册注意:path 就是我们网址访问的地址{path: '/news',name: 'news',component: News}
path和name是否首字母大写没有关系,完全可以直接复制粘贴News,这样就不必改变首字母大写了。
在文章列表点击需要传递ID编号到详情页,
router-link用法:
<li v-for="(item,index) in list" :key="index"> <router-link :to="{path: 'newsdetail', query: {id: item.id}}"> {{item.news_name}}</router-link></li>
如何传递多个参数呢?
query: {id: item.id, catid: cat}

详情页获取参数:this.$route.query.id
mounted () {var id = this.$route.query.idvar that = thisthat.artid = idaxios.post('/api/newsdetail', {parid: that.artid}).then(function (response) {that.content = response.data.content}) }
图3 文章详情页效果图
如何去掉router-link下划线:
直接设置a css样式 a{text-decoration:none}
如何使用公共的头部和底部文件:
打开src下app.vue
<template> <div id="app"><Header></Header><router-view></router-view><Footer></Footer> </div></template><script>import Header from '@/components/Header'import Footer from '@/components/Footer'export default { name: 'App', components: {Header, Footer }}</script>
template内添加 <Footer></Footer><Header></Header>,然后下边import导入,components注册,components文件夹内新建header.vue,footer.vue。
头部代码:
<template> <div class='header'><div class='logo'><img :src="logo"></div><div class='dh'><dl><dd><router-link to="/">首页</router-link></dd><dd><router-link to="/news">新闻中心</router-link></dd><dd><router-link to="/about">公司简介</router-link></dd><dd><router-link to="/contact">联系我们</router-link></dd></dl></div> </div></template><script>export default { name: 'header', data: () => ({logo: '/static/img/logo.png' })}</script>
打包导出:
使用npm run build命令打包,打开项目文件夹发现多了dist文件夹,复制该文件夹到我们的tp6网站根目录下(dist名称可以任意修改,比如手机网站是m或者mobile等),这个时候如果网址直接访问该文件夹,页面是空白的。
首页空白的解决方法:
编辑index.html发现css和js的路径是指向根目录的,我是把static放到了根目录下,直接暴力解决了,没有去修改路径。再次访问首页,已经正常,页面如下图。
图4 demo首页
tp6用来写接口(用于和html页面的交互):
返回文章列表示例:
public function newslist(){ $list=Db::name("web_news")->field('id,news_name')->select()->toArray();exit(json_encode(array('list'=>$list),JSON_UNESCAPED_UNICODE));}
使用域名重定向:
打开项目内config>index.js。vue默认的网址是localhost,端口是8080,我们可以改变为自己好记的网址,例如:www.xiangmu.com,打开C:WindowsSystem32driversetchosts,结尾处添加127.0.0.1 www.xiangmu.com,这样我们就可以使用网址加端口访问我们的vue网站,端口号在我们运行项目的时候会提示项目的访问网址。

这里说一个小技巧:直接打开项目所在文件夹,在地址栏点击直接输入cmd,相比运行,打开cmd,然后cd进入目录会方便点。
基本的规范
很多的警告,并不影响我们使用,但是也不建议忽视,只有严格按照要求来写代码,才能使我们的程序更加规范。
变量为字符串需要使用单引号,提示错误:Strings must use singlequote;变量值和前边冒号之间应该有一个空格,提示:Missing space before value for key;换行的时候,不能出现2个或者更多空白行,提示:More than 1 blank line not allowed;空格数错误,提示:Expected indentation of 7 spaces but found 8;文件名不要使用下划线,例如news_detail,提示:Identifier 'News_Detail' is not in camel case;如果在index.js或者main.js导入axios, 会提示:'axios' is defined but never used,我们直接在用到的页面导入就可以了,而不要在index 或者main.js导入;components内.vue文件写法应该是<template><div class='header'>并列的div</div></template>,如果没有总得div包含会提示:Component template should contain exactly one root element;表达式两边要留出空格,例如:that.newslist = response.data.newslist,如果不留出来会提示:Infix operators must be spaced;很多的时候都是出现了应该有空格,我们没有加上,按照提示加上空格就可以,越是按照要求写代码,我们的代码就会越规范。