Vue的使用
mvc
model view controller
mvvm
m=>model v=>view 双向数据绑定
数据在视图呈现:在表单里用v-model,在表单外用{{}},也可以用v-text
el:".app" 也可以写成 .$mount('.app')
<body>
<div class="app">
<input type="text" v-model="one">+<input type="text" v-model="two">=<span>{{one*1+two*1}}</span><span v-text="one"></span>
</div>
</body>
</html>
<script>
new Vue({ //启动vue
el:".app", //element,锁定vue作用的范围
data:{ //指定数据,json格式
one:0,
two:0
},
watch:{ //手动监控某一数据的变化
con(one){
if(one){
this.message=""
}
}
},
methods:{ //操作逻辑,放的是方法
result1(){
console.log("result1")
if(this.one>10){
return this.one*1-this.two*1
}else{
return this.one*1+this.two*1
}
}
},
computed:({ //动态的数据
result2(){
console.log("result2")
if(this.one>10){
return this.one*1+this.two*1
}else{
return this.one*1-this.two*1
}
}
})
})
</script>
指令
{{}}
模板引擎
<span>{{msg}}</span>
v-text
<span v-text="msg"></span>
<!-- 和下面的一样 -->
<span>{{msg}}</span>
v-html
更新元素的内容
v-model
完成双向数据绑定 (只能用在表单)
<input type="text" id="text" v-model="con" @keydown.13="add">
v-for
模板中循环
<tr v-for="item in values">
<td>{{item.id}}</td>
<td>{{item.name}}</td>
<td>{{item.sex}}</td>
<td>{{item.age}}</td>
</tr>
v-if v-else
模板中的判断
<div v-if="flag==true"></div>
<div v-else></div>
v-show
根据表达式之真假值,切换元素的 display
CSS 属性。
<div v-show="datas.length==0">没有内容</div>
v-on: => @
<input type="text" id="text" v-model="con" @keydown.13="add">
v-bind => :
<button type="button" class="btn btn-info" @click="changefn('all')" :style="{color:(changestate=='all'?'red':'#fff')}">全部</button>
组件化开发
一个组件里应该有完整的数据,完整的逻辑,完整的结构
<body>
<div class="box">
<car :datas="[{con:1},{con:2},{con:3}]"></car>
</div>
</body>
</html>
<script>
Vue.component("car",{
props:["datas"],
"template":`
<ul>
<li v-for="item in datas">{{item.con}}</li>
</ul>
`
// data:function () {
// return{
// datas:[{con:1},{con:2},{con:3},{con:4}]
// }
// }
})
new Vue({
el:".box",
})
</script>
构建vue2.0目录
vue -V 查看vue的版本 (热加载)
sudo npm install -g vue-cli 下载
vue init webpack aaaa 创建 vue基于webpack
y n n n y
src .vue就是一个完整的组件
cd aaaa
npm run serve
sudo npm uninstall -g vue-cli 卸载
构建vue3.0目录
sudo npm install -g @vue/cli 安装
vue create bbbb
手动创建
必选的:babel,Vuex,route
y n
cd bbbb
npm run serve
vue路由
引入vue.js vue-route.js
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>组件的制作
const Foo=Vue.component("Foo",{
template: `
<div @click="change">{{con}}</div>
`,
data:function () {
return{
con:"ljhblkbkjkj"
}
},
methods:{
change(){
this.con="123654788"
}
}
})
const Bar = { template: '<div>bar</div>' }建立路由
const router = new VueRouter({
routes:[
{ path: '/foo', component: Foo },
{ path: '/bar', component: Bar }
]声明vue 把路由放进vue中
const app = new Vue({
el:"#app",
router:router
})
开发
一、逻辑在服务器上
优点:首页加载速度快,业务逻辑清晰,工作量少
缺点:用户体验差,服务器压力大,不利于协同工作
二、逻辑在前端(ajax)
优点:用户体验佳,流畅,减轻服务器压力,有利于协同工作
缺点:首页加载慢,业务逻辑不清晰,工作量大
Vue的使用的更多相关文章
- Vue.js 和 MVVM 小细节
MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式,其核心是提供对View 和 ViewModel 的双向数据绑定,这使得ViewModel 的状态改变可以自 ...
- wepack+sass+vue 入门教程(三)
十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...
- wepack+sass+vue 入门教程(二)
六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...
- wepack+sass+vue 入门教程(一)
一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...
- Vue + Webpack + Vue-loader 系列教程(2)相关配置篇
原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ 使用预处理器 在 Webpack 中,所有的预处理器需要和一个相应的加载器一同使用.vue- ...
- Vue + Webpack + Vue-loader 系列教程(1)功能介绍篇
原文地址:https://lvyongbo.gitbooks.io/vue-loader/content/ Vue-loader 是什么? vue-loader 是一个加载器,能把如下格式的 Vue ...
- 关于Vue.js 2.0 的 Vuex 2.0,你需要更新的知识库
应用结构 实际上,Vuex 在怎么组织你的代码结构上面没有任何限制,相反,它强制规定了一系列高级的原则: 应用级的状态集中放在 store 中. 改变状态的唯一方式是提交mutations,这是个同步 ...
- Vue.js 2.0 和 React、Augular等其他框架的全方位对比
引言 这个页面无疑是最难编写的,但也是非常重要的.或许你遇到了一些问题并且先前用其他的框架解决了.来这里的目的是看看Vue是否有更好的解决方案.那么你就来对了. 客观来说,作为核心团队成员,显然我们会 ...
- 窥探Vue.js 2.0 - Virtual DOM到底是个什么鬼?
引言 你可能听说在Vue.js 2.0已经发布,并且在其中新添加如了一些新功能.其中一个功能就是"Virtual DOM". Virtual DOM是什么 在之前,React和Em ...
- 初探Vue
Vue.js(读音/vju:/,类似于view),是近来比较火的前端框架,但一直没有怎么具体了解.实现过,就知道个啥的MVVM啦,数据驱动啦,等这些关于Vue的虚概念. 由于最近,小生在公司中,负责开 ...
随机推荐
- FFmpeg命令行工具学习(一):查看媒体文件头信息工具ffprobe
一.简述 ffprobe是ffmpeg命令行工具中相对简单的,此命令是用来查看媒体文件格式的工具. 二.命令格式 在命令行中输入如下格式的命令: ffprobe [文件名] 三.使用ffprobe查看 ...
- 【从零开始搭建自己的.NET Core Api框架】(三)集成轻量级ORM——SqlSugar:3.1 搭建环境
系列目录 一. 创建项目并集成swagger 1.1 创建 1.2 完善 二. 搭建项目整体架构 三. 集成轻量级ORM框架——SqlSugar 3.1 搭建环境 3.2 实战篇:利用SqlSuga ...
- Hadoop伪分布式配置
一步一步来: 安装VMWARE简单,安装CentOS也简单 但是,碰到了一个问题:安装的虚拟机没有图形化界面 最后,我选择了CentOS-7-x86_64-DVD-1503-01.iso镜像 配置用户 ...
- [Java]LeetCode237. 删除链表中的节点 | Delete Node in a Linked List
Write a function to delete a node (except the tail) in a singly linked list, given only access to th ...
- [Swift]LeetCode1018. 可被 5 整除的二进制前缀 | Binary Prefix Divisible By 5
Given an array A of 0s and 1s, consider N_i: the i-th subarray from A[0] to A[i] interpreted as a bi ...
- python bz2模块
bz2模块提供了使用bzip2算法压缩和解压缩数据一套完整的接口. bz2模块包括: 用于读写压缩文件的open()函数和BZ2File类 用于一次性压缩和解压缩的compress() 和 decom ...
- [CERC2017] Intrinsic Interval
首先理清这奇葩题意表述 给出一个\(1\)到\(n\)的排列\(p[]\)和\(m\)次询问,每次询问覆盖区间\([l,r]\)的最小区间\([a,b]\),满足\([a,b]\)内的元素排序后是连续 ...
- cassandra 3.x官方文档(7)---内部原理之如何读写数据
写在前面 cassandra3.x官方文档的非官方翻译.翻译内容水平全依赖本人英文水平和对cassandra的理解.所以强烈建议阅读英文版cassandra 3.x 官方文档.此文档一半是翻译,一半是 ...
- 【MongoDb入门】15分钟让你敢说自己会用MongoDB了
一.MongDB是什么呢,我该如何下手呢? MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. 如果小伙伴你的机器上还没有安装Mon ...
- [linux]孤儿进程与僵尸进程
转载自:http://www.cnblogs.com/Anker/p/3271773.html 一.前言 之前在看<unix环境高级编程>第八章进程时候,提到孤儿进程和僵尸进程,一直对这两 ...