vue.js初學(xué)入門教程(1)
Vue.js是當(dāng)下很火的一個(gè)JavaScript MVVM庫,它是以數(shù)據(jù)驅(qū)動(dòng)和組件化的思想構(gòu)建的。相比于Angular.js,Vue.js提供了更加簡潔、更易于理解的API,使得我們能夠快速地上手并使用Vue.js。
0.MVVM
什么是MVVM?就是Model-View-ViewModel。

ViewModel是Vue.js的核心,它是一個(gè)Vue實(shí)例。
不太懂也沒關(guān)系,慢慢就懂了。
1.基礎(chǔ)示例
代碼:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
<title></title>
</head>
<body>
<div id="didi-navigator">
<ul>
<li v-for="tab in tabs">
{{ tab.text }}
</li>
</ul>
</div>
<script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
new Vue({
el: '#didi-navigator',
data: {
tabs: [
{ text: '巴士' },
{ text: '快車' },
{ text: '專車' },
{ text: '順風(fēng)車' },
{ text: '出租車' },
{ text: '代駕' }
]
}
})
</script>
</body>
</html>

使用Vue的過程就是定義MVVM各個(gè)組成部分的過程的過程。
· 定義View
· 定義Model
· 創(chuàng)建一個(gè)Vue實(shí)例或"ViewModel",它用于連接View和Model
2.數(shù)據(jù)綁定
2.1 插值
有時(shí)候只需渲染一次數(shù)據(jù),后續(xù)數(shù)據(jù)變化不再關(guān)心,可以通過“*”實(shí)現(xiàn):
<span>Text: {{*text}}</span>
雙大括號(hào)標(biāo)簽會(huì)把里面的值全部當(dāng)作字符串來處理,如果值是HTML片段,則可以使用三個(gè)大括號(hào)來綁定:
<div>Logo: {{{logo}}}</div>
Logo: ‘<span>DDFE</span>'
2.2 表達(dá)式
Mustache標(biāo)簽也接受表達(dá)式形式的值。
3.指令(上)
v-if指令
v-show指令
v-else指令
v-for指令
v-bind指令
v-on指令
v-model指令
v-if:是否渲染。
v-show:肯定渲染,是否顯示。
其中,v-show不支持<template語法>。一般來說,v-if有更高的切換消耗,而v-show有更高的初始渲染消耗。因此,如果需要頻繁地切換,則使用v-show較好;如果在運(yùn)行時(shí)條件不大可能改變,則使用v-if較好。另外,將v-show用在組件上時(shí),因?yàn)橹噶畹膬?yōu)先級(jí)v-else會(huì)出現(xiàn)問題,可以用另一個(gè)v-show替換v-else。
3.1 關(guān)于v-for
使用基礎(chǔ)可參看http://www.dhdzp.com/article/96364.htm。
補(bǔ)充:
Vue.js增加了兩個(gè)方法觀測變化:$set、$remove。
3.1.1 應(yīng)該盡量避免直接設(shè)置數(shù)據(jù)綁定的數(shù)組元素
因?yàn)檫@些變化不會(huì)被Vue.js檢測到,因而也不會(huì)更新視圖渲染。這時(shí),我們可以使用$set方法:
demo.item.$set(0,{childMsg:'Changed!'})
$remove是splice的語法糖,用于從目標(biāo)數(shù)組中查找并刪除元素。
demo.item.$remove(item)
3.1.2 有時(shí)可能需要用全新對(duì)象來替換數(shù)組
Vue.js應(yīng)盡可能地復(fù)用已有實(shí)例。如果沒有唯一的鍵供追蹤,則可以使用track-by=”$index”,它強(qiáng)制讓v-for進(jìn)入原位更新模式:片段不會(huì)被移動(dòng),而是簡單地以對(duì)應(yīng)索引的新值刷新。這時(shí)DOM節(jié)點(diǎn)不再映射數(shù)組元素順序的改變,不能同步臨時(shí)狀態(tài)(比如<input>元素的值),以及組件的私有狀態(tài)。
因?yàn)閖s的限制,Vue.js不能檢測到下面數(shù)組的變化:
直接用索引設(shè)置元素,如vm.items[0]={}。
修改數(shù)據(jù)的長度,如vm.items.length = 0。
前一個(gè)問題可用$set解決,后一個(gè)問題只需用一個(gè)空數(shù)組替換items即可。
3.1.3 v-for可以和vue.js提供的內(nèi)置過濾器(filterBy)或排序(orderBy)數(shù)據(jù)一起使用
filterBy的例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<input v-model="searchText" />
<ul>
<li v-for="user in users | filterBy searchText in 'name'">{{user.name}}</li>
</ul>
<script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
var haha = new Vue({
el:'body',
data:{
users:[
{
name:'快車',
tag:'1'
},
{
name:'慢車',
tag:'2'
},
{
name:'好車',
tag:'3'
},
{
name:'破車',
tag:'4'
}
]
}
})
</script>
</body>
</html>

當(dāng)我搜破車的時(shí)候:

orderBy的例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<ul>
<li v-for="user in users | orderBy field reverse">{{user.name}}</li>
</ul>
<script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
var demo = new Vue({
el:'body',
data:{
field:'tag',
reverse:false, // 顛倒
users:[
{
name:'快車',
tag:'2'
},
{
name:'慢車',
tag:'3'
},
{
name:'好車',
tag:'1'
},
{
name:'破車',
tag:'0'
}
]
}
})
</script>
</body>
</html>

其他:
v-bind指令可以縮寫為一個(gè)冒號(hào),v-on指令可以縮寫為@符號(hào)。
v-model指令后面可以添加number、lazy、debounce參數(shù)。
Number可以將用戶的輸入轉(zhuǎn)換為Number類型(如果原值的轉(zhuǎn)換結(jié)果為NaN,則返回原值)。
在input中時(shí)添加lazy將數(shù)據(jù)改到在change事件中發(fā)生。
Debounce可設(shè)置延時(shí)。
參考:大神寫的:http://www.dhdzp.com/article/96426.htm《vue.js權(quán)威指南》
本文已被整理到了《Vue.js前端組件學(xué)習(xí)教程》,歡迎大家學(xué)習(xí)閱讀。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
element ui 表格動(dòng)態(tài)列顯示空白bug 修復(fù)方法
今天小編就為大家分享一篇element ui 表格動(dòng)態(tài)列顯示空白bug 修復(fù)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
uni-app中App與webview雙向?qū)崟r(shí)通信詳細(xì)代碼示例
在移動(dòng)應(yīng)用開發(fā)中,uni-app是一個(gè)非常流行的框架,它允許開發(fā)者使用一套代碼庫構(gòu)建多端應(yīng)用,包括H5、小程序、App等,這篇文章主要給大家介紹了關(guān)于uni-app中App與webview雙向?qū)崟r(shí)通信的相關(guān)資料,需要的朋友可以參考下2024-07-07
element?ui?From表單校驗(yàn)不生效問題解決
表單校驗(yàn)是注冊(cè)環(huán)節(jié)中必不可少的操作,表單校驗(yàn)可以提醒用戶填寫數(shù)據(jù)規(guī)則以確保用戶提交數(shù)據(jù)的有效性,本文主要介紹了element?ui?From表單校驗(yàn)不生效問題解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
在Vue中實(shí)現(xiàn)網(wǎng)頁截圖與截屏功能詳解
在Web開發(fā)中,有時(shí)候需要對(duì)網(wǎng)頁進(jìn)行截圖或截屏,Vue作為一個(gè)流行的JavaScript框架,提供了一些工具和庫,可以方便地實(shí)現(xiàn)網(wǎng)頁截圖和截屏功能,本文將介紹如何在Vue中進(jìn)行網(wǎng)頁截圖和截屏,需要的朋友可以參考下2023-06-06
vue如何點(diǎn)擊多個(gè)tab標(biāo)簽打開關(guān)閉多個(gè)頁面
這篇文章主要介紹了vue如何點(diǎn)擊多個(gè)tab標(biāo)簽打開關(guān)閉多個(gè)頁面,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
Vue中接收二進(jìn)制文件流實(shí)現(xiàn)pdf預(yù)覽的方法
本文主要介紹了Vue中接收二進(jìn)制文件流實(shí)現(xiàn)pdf預(yù)覽的方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12

