Vue.js 指南-基础
Installation
可以使用的方式:
script
标签方式加载vue.js
- cdn
https://unpkg.com/vue@2.0.5/dist/vue.js
- npm
Introduction
- 通过指定的语法渲染js变量
- DOM元素与变量绑定,同步更新,无需手动操纵DOM
- 通过
vue
标签属性,完成绑定data,绑定事件,条件语句以及循环等特性 - 创建自定义可复用的组件,可直接在html标签中使用
The Vue Instance
Vue
构造方法创建实例,并且可以扩展构造方法创建可重用的组件(继承?)- 每一个
Vue
实例都代理了data
参数中所有的属性,并且如果在Vue对象实例化之前你的自定义变量绑定到了data中,那么他们的值是时刻同步的 - 每个
Vue
对象在实例化的过程中,经历了一系列的过程,就是有它的生命周期
Template Syntax
Vue
使用基于HTML的语法,允许你将渲染到DOM中元素与Vue
实例中的data数据绑定Vue
把模板数据编译到虚拟DOM的渲染方法中,根据app不同的状态,实现最少量的组件的重新渲染- {{}}法上可以渲染文本、可以支持javascript表达式,可以通过管道实现过滤
Computed Properties and Watchers
- {{}}语法中可以使用js表达式,但是并不推荐,不易于维护,不利于调试,引入 computed属性,compulted属性依赖于现有的属性,只要依赖值没变,其值不变,页面中多处使用可以直接返回计算好的值,与之对应的用方法实现,每次都要执行一遍
- 对于数据和页面的rective,compluted可以满足大多数情形,当你需要完成异步并且有大量的数据计算响应等操作,可以使用
watch
选项 - 总结:
compluuted
与watch
的目的都是监听Vue
实例数据的变化,并作出响应
Class and Style Bindings
- 使用
Vue
定义的属性v-bind:class
可以进行样式类的绑定,支持丰富的格式,可以使用对象的方式在vue
data option中定义,可以使用数组传递多个类名,可以依赖于现有的data使用compluted属性,可以跟现有的html标签类混用等等 v-bind:style
可直接绑定书写行内样式,支持对象方式、数组方式
Conditional Rendering
- 条件标签
v-if
,v-show
,可以做条件判断来进行html元素的显示 - 不同点在于
v-if
根据值的变化每次重新渲染,v-show
等价于display:show|none
也就是元素是在页面中渲染好的
Event Handling
v-on
标签绑定各种事件,可以做v-on:click="counter += 1"
这种简单的处理,也可以调用Vue
中方法(方法可将原生的DOM event通过$event
传递)- 经常用到的阻止事件冒泡或阻止事件的默认行为在
Vue
中可以与v-on
搭配使用点语法.stop .prevent .capture .self
来实现,不需要再去关心具体的DOM事件细节 - 针对键盘的
key
值监听,Vue
提供也提供了简单的绑定语法v-on:keyup.键值
,也可使用vue提供的定义好的常用键值的别名
Form Input Bindings
v-model
可以处理基本的用户输入(input)、复选框、单选框等的值赋值给v-model指定的变量- 仅仅使用
v-model
只可以获取用户输入的字符串或者true false(单、富选框),可以使用v-bind
将input的value与vue的属性绑定,这样可以动态的修改
Components
- 组件用来扩展现有的html标签并进行封装重用
- 使用自定义components需要在实例化Vue对象之前确保组件已经注册
- 除注册为全局组件之外,可以注册为某一个vue实例的本地组件
- 在页面中直接使用自定义组件时,浏览器会无法解析,需要使用
is=组件名
- 组件中的
data option
必须为一个function
,否则console 报 warnning - 组件复用不可避免的需要不同组件嵌套使用,涉及到数据的向下传递,
Vue
通过props option
传递【注:props在js中的驼峰命名在html中需要改为连字符】 - 对于组件需要接收的参数,Vue提供了参数验证
- 子组件与父组件的通信是通过
customer events
即自定义事件 v-on:事件名
来监听子组件可能触发的事件v-on:click.native=""
同样可以监听原生的JavaScript事件- 非父子关系的组件也可以通过
hook
的方式完成通讯
Vue.js 指南-基础的更多相关文章
- Vue.js应用基础
声明 这篇博文是我的Vue学习记录,其中参杂了不少我个人的理解,由于我并没有继续学习Vue的源码,所以不能保证这些理解都是正确的.如果这篇博文有幸被你读到,请带着批判的心情去审视它. 如果你发现了其中 ...
- Vue.js的基础学习
Vue.js的基础网上很多,这里不记录 开始正式页面的开发 1.页面加载时请求数据 methods: { post() { //发送post请求 this.$http.post('../../ashx ...
- Vue.js教程--基础(实例 模版语法template computed, watch v-if, v-show v-for, 一个组件的v-for.)
官网:https://cn.vuejs.org/v2/guide/index.html Vue.js 的核心是一个允许采用简洁的模板语法来声明式地将数据渲染进 DOM 的系统. 视频教程:https: ...
- Vue.JS学习基础
= 导航 顶部 vue.js介绍 vue.js实例 模板语法 计算属性 样式绑定 条件渲染 列表渲染 事件处理器 表单控件绑定 组件 顶部 vue.js介绍 vue.js实例 模板语法 计 ...
- Vue.js教程--基础2(事件处理 表单输入绑定
事件处理 表单输入绑定 事件处理 监听v-on 监听 DOM 事件,并在触发时运行一些 JavaScript 代码. 可以在v-on:click=''加内联语句. 有时也需要在内联语句处理器中访问原始 ...
- vue.js的基础与语法
Vue的实例 创建第一个实例: {{}} 被称之为插值表达式.可以用来进行文本插值. <!DOCTYPE html> <html lang="en"> &l ...
- Vue.js 基础指令实例讲解(各种数据绑定、表单渲染大总结)——新手入门、高手进阶
Vue.js 是一套构建用户界面的渐进式框架.他自身不是一个全能框架--只聚焦于视图层.因此它非常容易学习,非常容易与其它库或已有项目整合.在与相关工具和支持库一起使用时,Vue.js 也能完美地驱动 ...
- Vue.js 基础快速入门
Vue.js是一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的.Vue.js提供了简洁.易于理解的API,使得我们能够快速地上手并使用Vue.js 如果之前已经习惯了用jQue ...
- Vue.js——60分钟快速入门
Vue.js介绍 Vue.js是当下很火的一个JavaScript MVVM库,它是以数据驱动和组件化的思想构建的.相比于Angular.js,Vue.js提供了更加简洁.更易于理解的API,使得我们 ...
随机推荐
- api 和 abi的区别
156down vote API: Application Program Interface This is the set of public types/variables/functions ...
- TortoiseSVN历史版本安装及svn服务器搭建
一.TortoiseSVN安装 1.TortoiseSVN下载 网址如下:https://tortoisesvn.net/downloads.html 进入客户端下载页面,根据你的电脑选择是64位 ...
- 竞争激烈的洗衣O2O
今日,洗衣O2O干洗客宣布已获得千万美金Pre-A轮融资,投资方为新加坡某资本,具体信息尚不便透露. “干洗客”是36氪此前报道过的洗衣O2O服务商,2013年7月诞生于上海,2014年12月经历重组 ...
- Haskell Seq函数和严格计算
参考链接http://stackoverflow.com/questions/11046590/the-seq-function-and-strictness https://wiki.haskell ...
- 分离JavaScript
分离JavaScript类似于使用style属性,在HTML文档里使用诸如onclick之类的属性也是一种既没有效率又容易引发问题的做法.如果我们用一个"挂钩",就像CSS机制中的 ...
- 一步步优化JVM四:决定Java堆的大小以及内存占用
到目前为止,还没有做明确的优化工作.只是做了初始化选择工作,比如说:JVM部署模型.JVM运行环境.收集哪些垃圾回收器的信息以及需要遵守垃圾回收原则.这一步将介绍如何评估应用需要的内存大小以及Java ...
- 单身福利来了:VR恋人为你量身定制一个女朋友
相对于传统视频体验,VR视频给人带来了更加真实的体验.特别是对于单身狗来说,能在VR中拥有一个虚拟的恋人可谓是莫大的心灵安慰.近日,上海微雁文化传媒有限公司正式发布了首款养成类手机应用VR恋人. VR ...
- C#调用winhttp组件 POST登录迅雷
下面是封装好的winhttp类 using System; using System.Collections.Generic; using System.Linq; using System.Text ...
- Linode VPS上架日本东京2号机房,性能速度评测报告(推荐)
我非常喜欢的海外免备案vps品牌linode日本机房长期缺货,中国用户想买都买不到.不过近日,陆续有国内朋友收到了Linode邀请,Tokyo 2日本东京机房开启内测,很快正式上架销售. 苦等太久的站 ...
- Shell 脚本计算时间差
在shell脚本中统计程序执行完毕所需要的时间不像在java中使用System.currentTimeMillis()方便 稍微记录一下,以供备用,免得又去花时间想(统计程序执行消耗多少s): sta ...