Vue.js再入门

Vue.js 是一套构建用户界面的 渐进式框架。与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计。因此,我们既可以拿Vue当作普通的js模板引擎使用,也可以拿它开发的大型复杂单页应用。

Vue.js 不支持 IE8 及其以下版本,因为 Vue.js 使用了 IE8 不能实现的 ECMAScript 5 特性。 Vue.js 支持所有兼容 ECMAScript 5 的浏览器

Vue.js实例

Vue 实例,实则也就是 ViewModel(数据 + 函数),都是通过构造函数 Vue 创建

var vm = new Vue({
    name:'root',
    el:"#app",
    // 数据
    data: { a: 1 } / Function, // data类型根实例为Object,组件中为Function
    props:[]/{}, // 设置父组件传递给子组件的数据限制
    computed:{}, // 计算属性
    watch:{}, // 监控属性
    methods:{}, // 事件操作
    // 资源
    directives:{}, // 内部指令
    filters:{}, // 内部过滤器
    components:{}, // 内部组件
    // 生命周期:实例创建 => 编译挂载 => 组件更新 => 销毁
    beforeCreate(){
        console.log('beforeCreate ==> 实例创建')
    },
    created(){
        // 可以操作data, 但未生成DOM(未挂载)发起异步请求,初始化组件状态数据 data
        console.log('created ==> 实例创建完成,属性已绑定')
    },
    beforeMount(){
        console.log('beforeMount ==> 模板编译/挂载之前')
    },
    mounted(){
        // 已生成DOM到document中,可访问this.$el属性
        console.log('mounted ==> 模板编译/挂载之后')
    },
    beforeUpdate(){
        console.log('beforeUpdate ==> 组件更新之前')
    },
    updated(){
        // 操作DOM $('#box1')
        console.log('updated ==> 组件更新之后')
    },
    activated(){
        // 操作DOM $('#box1')
        console.log('activated ==> 组件被激活时(for keep-alive组件)')
    },
    deactivated(){
        console.log('deactivated ==> 组件被移除时(for keep-alive组件)')
    },
    beforeDestroy(){
        // 解除事件绑定,销毁非Vue组件实例等 如:this.$off('event1') select2.destory()
        console.log('beforeDestroy ==> 组件销毁之前')
    },
    destroyed(){
        console.log('destroyed ==> 组件销毁之后')
    }
})

模版语法

文本插值(v-text,v-html)

  • 使用 {{ }} / <span v-text="msg"></span> 绑定数据
  • {{ }} 纯文本绑定,单向,随vm变化而变化
  • <span v-once>{{ msg }}</span> 纯文本,单次,不跟随vm变化
  • <span v-html="msg"></span> 不转义html标签,绑定html

属性绑定(v-bind)

- 使用 `v-bind` 指令绑定数据至标签属性
<!-- 绑定一个属性 -->
![](imageSrc)
<!-- 缩写 -->
![](imageSrc)
<!-- with inline string concatenation -->
![]('/path/to/images/' + fileName)
<!-- class 绑定 -->
<div :class="{ red: isRed }"></div>
<div :class="[classA, classB]"></div>
<div :class="[classA, { classB: isB, classC: isC }]">
<!-- style 绑定 -->
<div :style="{ fontSize: size + 'px' }"></div>
<div :style="[styleObjectA, styleObjectB]"></div>
<!-- 绑定一个有属性的对象 -->
<div v-bind="{ id: someProp, 'other-attr': otherProp }"></div>
<!-- 通过 prop 修饰符绑定 DOM 属性 -->
<div v-bind:text-content.prop="text"></div>
<!-- prop 绑定. “prop” 必须在 my-component 中声明。 -->
<my-component :prop="someThing"></my-component>
<!-- XLink -->
<svg><a :xlink:special="foo"></a></svg>

事件绑定(v-on)

- 使用 `v-on` 指令绑定事件
<!-- 方法处理器 -->
<button v-on:click="doThis"></button>
<!-- 内联语句 -->
<button v-on:click="doThat('hello', $event)"></button>
<!-- 缩写 -->
<button @click="doThis"></button>
<!-- 停止冒泡 -->
<button @click.stop="doThis"></button>
<!-- 阻止默认行为 -->
<button @click.prevent="doThis"></button>
<!-- 阻止默认行为,没有表达式 -->
<form @submit.prevent></form>
<!-- 串联修饰符 -->
<button @click.stop.prevent="doThis"></button>
<!-- 键修饰符,键别名 -->
<input @keyup.enter="onEnter">
<!-- 键修饰符,键代码 -->
<input @keyup.13="onEnter">
<!-- the click event will be triggered at most once -->
<button v-on:click.once="doThis"></button>

表单绑定(v-model)

// 文本框
<input v-model="message" placeholder="edit me">
// 文本域(支持换行)
<textarea v-model="message" placeholder="add multiple lines"></textarea>
// 复选框
// 单选(返回 true/false )
<input type="checkbox" id="checkbox" v-model="checked">
<label for="checkbox">{{ checked }}</label>
// 多选 (返回一个数组 ['jack', 'john'])
<input type="checkbox" id="jack" value="Jack" v-model="checkedNames">
<label for="jack">Jack</label>
<input type="checkbox" id="john" value="John" v-model="checkedNames">
<label for="john">John</label>
<input type="checkbox" id="mike" value="Mike" v-model="checkedNames">
<label for="mike">Mike</label>
<br>
<span>Checked names: {{ checkedNames }}</span>
//单选框 (返回选中的值)
<input type="radio" id="one" value="One" v-model="picked">
<label for="one">One</label>
<br>
<input type="radio" id="two" value="Two" v-model="picked">
<label for="two">Two</label>
// 下拉框
// 单选 (返回选中的值)
<select v-model="selected">
  <option>A</option>
  <option>B</option>
  <option>C</option>
</select>
// 多选(返回一个数组 ['A','B'])
<select v-model="selected" multiple>
  <option>A</option>
  <option>B</option>
  <option>C</option>
</select>

列表渲染(v-for)

data: {
 items: [
    {message: 'Foo' },
    {message: 'Bar' }
  ]
  object: {
     firstName: 'John',
     lastName: 'Doe',
     age: 30
   }
}
//基本用法
<ul id="example-1">
    <li v-for="item in items">
        {{item.message}}
    </li>
</ul>
//为数组索引指定别名(或者用于对象的键)
<div v-for="(item, index) in items">
  {{index}} - {{item.message}}
</div>
<div v-for="(val, key) in object">
  {{ key }} : {{ val}}
</div>
<div v-for="(val, key, index) in object">
  {{key}} : {{val}} : {{index}}
</div>

条件判断(v-show,v-if,v-else,v-else-if)

**v-if**
//切换单个元素
<h1 v-if="ok">Yes</h1>
<h1 v-else>No</h1>

//切换多个元素
<template v-if="ok">
  <h1>Title</h1>
  <p>Paragraph 1</p>
  <p>Paragraph 2</p>
</template>

//多条件判断
<div v-if="type === 'A'">
  A
</div>
<div v-else-if="type === 'B'">
  B
</div>
<div v-else-if="type === 'C'">
  C
</div>
<div v-else>
  Not A/B/C
</div>

**v-show**
<h1 v-show="ok">Hello!</h1>
//不同的是有 v-show 的元素会始终渲染并保持在 DOM 中。v-show 是简单的切换元素的 CSS 属性 display 。
//注意 v-show 不支持 <template> 语法。


指令

  • 带有 v- 前缀的特殊属性
  • 当其表达式的值改变时相应地将某些行为应用到 DOM 上
  • v-bind/v-for/v-html/v-on/v-if/...
  • v-bind 缩写 <a v-bind:href="url"></a><a :href="url"></a>
  • v-on 缩写 <a v-on:click="doSomething"></a><a @click="doSomething"></a>

注册指令

//全局注册
// 注册一个全局自定义指令 v-focus
Vue.directive('focus', {
    // 当绑定元素插入到 DOM 中。
    inserted: function (el) {
        // 聚焦元素
        el.focus()
    }
})
//局部注册
directives: {
    focus: {
        // 指令的定义---
    }
}
//使用
<input v-focus />

过滤器

  • 使用 | 对原始值进行处理
  • 用于属性绑定与 {{ }}
  • {{ msg | capitalize }} <a :id="msgId | formatId"></a>
  • 可以串联 {{ msg | filterA | filterB }}
  • 可以接收参数 {{ msg | filterA(arg1, arg2) }}

注册过滤器

//全局注册
Vue.filters('capitalize',value=>{
    if (!value) return ''
    value = value.toString()
    return value.charAt(0).toUpperCase() + value.slice(1)
})
//局部注册
filters: {
    capitalize: function (value, arg1) {
        if (!value) return ''
        value = value.toString()
        return value.charAt(0).toUpperCase() + value.slice(1)
    }
}
//使用
<span>{{msg | capitalize(arg1) }}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容

  • Vue 实例 属性和方法 每个 Vue 实例都会代理其 data 对象里所有的属性:var data = { a:...
    云之外阅读 2,204评论 0 6
  • 这篇笔记主要包含 Vue 2 不同于 Vue 1 或者特有的内容,还有我对于 Vue 1.0 印象不深的内容。关于...
    云之外阅读 5,047评论 0 29
  • 下载安装搭建环境 可以选npm安装,或者简单下载一个开发版的vue.js文件 浏览器打开加载有vue的文档时,控制...
    冥冥2017阅读 6,033评论 0 42
  • 1.安装 可以简单地在页面引入Vue.js作为独立版本,Vue即被注册为全局变量,可以在页面使用了。 如果希望搭建...
    Awey阅读 11,006评论 4 129
  • 作/董晓禾 那首牛仔手里吉他的叙述 如同你离去后雨滴坠落在心里的休止符 品着你的吻留在发间的格式 是连续的二分音符...
    禾仙姑Shawn阅读 575评论 0 1