Vuejs的指令及組件用法總結


vuejs介紹

Vue.js是當下很火的一個JavaScript MVVM庫,它是以數據驅動和組件化的思想構建的。相比於Angular.js,Vue.js提供了更加簡潔、更易於理解的API,使得我們能夠快速地上手並使用Vue.js。
如果你之前已經習慣了用jQuery操作DOM,學習Vue.js時請先拋開手動操作DOM的思維,因為Vue.js是數據驅動的,你無需手動操作DOM。它通過一些特殊的HTML語法,將DOM和數據綁定起來。一旦你創建了綁定,DOM將和數據保持同步,每當變更了數據,DOM也會相應地更新。
當然了,在使用Vue.js時,你也可以結合其他庫一起使用,比如jQuery。

mvvm模式

http://cn.vuejs.org/images/mvvm.png
ViewModel是Vue.js的核心,它是一個Vue實例。Vue實例是作用於某一個HTML元素上的,這個元素可以是HTML的body元素,也可以是指定了id的某個元素。
當創建了ViewModel后,雙向綁定是如何達成的呢?
首先,我們將上圖中的DOM Listeners和Data Bindings看作兩個工具,它們是實現雙向綁定的關鍵。
從View側看,ViewModel中的DOM Listeners工具會幫我們監測頁面上DOM元素的變化,如果有變化,則更改Model中的數據;
從Model側看,當我們更新Model中的數據時,Data Bindings工具會幫我們更新頁面中的DOM元素。

helloworld示例

		<!--這是我們的View-->
		<div id="app">
			{{ message }}
		</div>
		
		// 這是我們的Model
		var exampleData = {
			message: 'Hello World!'
		}

		// 創建一個 Vue 實例或 "ViewModel"
		// 它連接 View 與 Model
		new Vue({
			el: '#app',
			data: exampleData
		})

使用Vue的過程就是定義MVVM各個組成部分的過程的過程。

定義View
定義Model
創建一個View實例或"ViewModel",它用於連接View和Model
在創建Vue實例時,需要傳入一個選項對象,選項對象可以包含數據、掛載元素、方法、模生命周期鈎子等等。
在這個示例中,選項對象的el屬性指向View,el: '#app'表示該Vue實例將掛載到
<div id="app">...</div>這個元素;data屬性指向Model,data: exampleData表示我們的Model是exampleData對象。
Vue.js有多種數據綁定的語法,最基礎的形式是文本插值,使用一對大括號語法,在運行時{{ message }}會被數據對象的message屬性替換,所以頁面上會輸出"Hello World!"。

雙向綁定

MVVM模式本身是實現了雙向綁定的,在Vue.js中可以使用v-model指令在表單元素上創建雙向數據綁定。

<!--這是我們的View-->
<div id="app">
	<p>{{ message }}</p>
	<input type="text" v-model="message"/>
</div>

將message綁定到文本框,當更改文本框的值時,<p>{{ message }}</p> 中的內容也會被更新。
反過來,如果改變message的值,文本框的值也會被更新

vuejs常用指令

什么是指令呢?上面我們用到的v-model就是一個指令
Vue.js的指令是以v-開頭的,它們作用於HTML元素,指令提供了一些特殊的特性,將指令綁定在元素上時,指令會為綁定的目標元素添加一些特殊的行為,我們可以將指令看作特殊的HTML特性(attribute)。
Vue.js提供了一些常用的內置指令,接下來我們將介紹以下幾個內置指令:

  • v-if指令
  • v-show指令
  • v-else指令
  • v-for指令
  • v-bind指令
  • v-on指令

v-if指令

v-if是條件渲染指令,它根據表達式的真假來刪除和插入元素
基本語法:
v-if="expression"
expression是一個返回布爾值的表達式,表達式可以是一個布爾屬性,也可以是一個返回布爾的運算式。

<div id="app">
			<div v-if="isMale">男士</div>
			<div v-if="age>=20">age:{{age}}</div>
		</div>
		
var vm = new Vue({
			el: '#app',
			data: {
				age:25,
				isMale:true,
			}
		})

v-show指令

v-show和v-if區別。
v-show不管條件是否成立,都會渲染html,而v-if只有條件成立才會渲染

先看兩個截圖,第一個是當isMale為true時,第二張圖是isMale為false條件不成立時,可以看到v-if的html並沒有渲染出來,
而使用v-show的div僅僅是更改了它的樣式display: none;


<div id="app">
			<div v-if="isMale">男士v-if</div>
			<div v-show="isMale">男士v-show</div>
		</div>
var vm = new Vue({
			el: '#app',
			data: {
				isMale:false
			}
		})

v-else指令

v-else指令與v-if或者v-show同時使用,v-if條件不成立則會顯示v-else內容

<div id="app">
			<div v-if="isMale">男士</div>
			<div v-else>女士</div>
		</div>
		var vm = new Vue({
			el: '#app',
			data: {
				isMale:true
			}
		})

v-for指令

v-for指令基於一個數組渲染一個列表,它和JavaScript的遍歷語法相似
v-for="item in list"
list是一個數組,item是當前遍歷的數組元素
v-for="(item,index) in list"其中index是當前循環的索引,下標從0開始

<div id="app">
			<table>
				<tr class="thead">
					<td>序號</td>
					<td>姓名</td>
					<td>年齡</td>
				</tr>
				<tr v-for="(item,index) in list">
					<td v-text="index+1"></td>
					<td v-text="item.name"></td>
					<td v-text="item.age"></td>
				</tr>
			</table>
		</div>
		
var vm = new Vue({
			el: '#app',
			data: {
				list:[{
					name:'章三',
					age:18
				},{
					name:'李四',
					age:23
				}]
			}
		})

v-bind指令

v-bind動態地綁定一個或多個特性,可以在其名稱后面帶一個參數,中間放一個冒號隔開,這個參數通常是HTML元素的特性(attribute),如v-bind: class

class可以和v-bind:class同時存在 ,也就是說有class了,再添加v-bind:class並不會覆蓋原來的樣式類,而是在原來基礎上添加新的類名

<div id="app">
			<img v-bind:src="img" class="logo" 
				v-bind:class="isLogo?'':'product'" 
				v-bind:style="{'border':hasBorder?'2px solid red':''}"></img>
		</div>
		
		var vm = new Vue({
			el: '#app',
			data: {
				img:'https://www.baidu.com/img/bd_logo1.png',
				isLogo:false,
				hasBorder:true
			}
		})

以上v-bind:src也可簡寫成:src,修改上面代碼

<div id="app">
			<img :src="img" class="logo" 
				:class="isLogo?'':'product'" 
				:style="{'border':hasBorder?'2px solid red':''}"></img>
		</div>

v-on指令

v-on用於監聽DOM事件,用法和v-bind類似,例如給button添加點擊事件
<button v-on:click="show">
同樣,和v-bind一樣,v-on也可以使用簡寫,用@符號代替,修改代碼:
<button @click="show">

我們來看個例子:

以下是一個點擊隱藏和顯示p文本段落的代碼

<div id="app">
			<p v-show="isShow">微風輕輕的吹來,帶來了一絲絲涼意</p>
			<div>
				<button type="button" v-on:click="show(1)">顯示</button>
				<button type="button" v-on:click="show(0)">隱藏</button>
			</div>
		</div>
		
		var vm = new Vue({
			el: '#app',
			data: {
				isShow:true
			},
			methods:{
				show:function(type){
					if(type){
						this.isShow = true;
					}else{
						this.isShow = false;
					}
				}
			}
		})

綜合示例

<div id="app">
			<div class="title">添加新用戶</div>
			<div class="form">
				姓名:<input type="text" v-model="person.name"><br/>
				年齡:<input type="text" v-model="person.age"><br/>
				<button class="btn" type="button" @click="add">添加</button>
			</div>
			<table>
				<tr class="thead">
					<td>序號</td>
					<td>姓名</td>
					<td>年齡</td>
					<td>操作</td>
				</tr>
				<tr v-for="(item,index) in list">
					<td v-text="index+1"></td>
					<td v-text="item.name"></td>
					<td v-text="item.age"></td>
					<td>
						<a href="javascript:;" @click="deleteItem(index)">刪除</a>
						<a v-if="item.age>=25" href="javascript:;" @click="marry(index)">可以結婚了</a>
					</td>
				</tr>
			</table>
		</div>
		new Vue({
			el: '#app',
			data: {
				person:{
					name:'',
					age:'',
				},
				list:[{
					name:'章三',
					age:18
				},{
					name:'李四',
					age:23
				}]
			},
			methods:{
				add:function(){
					this.list.push(this.person);
					this.person = {name:'',age:''};
				},
				deleteItem:function(index){
					// 刪除一個數組元素
					this.list.splice(index,1);
				},
				marry:function(){
					alert("不好意思,你沒有女朋友結不了婚");
				}
			},
			created:function(){
			}
		})

vue組件

組件 (Component) 是 Vue.js 最強大的功能之一,使用組件化方式開發,可以封裝可重用的代碼,減少重復勞動

接下來,我們來注冊一個組件
語法Vue.component(tagName, options)

注冊組件

		Vue.component('component-a', {
		  template: '<div>component-a</div>'
		})

component-a是注冊的組件標簽,下面就可以使用這個組件了

<div id="app">
			 <component-a></component-a>
		</div>

// 創建根實例
new Vue({
  el: '#app'
})

最后,渲染為:

<div id="app">
	<div>component-a!</div>
</div>

通過Vue.component方式注冊的組件是一個全局組件 ,我們還可以創建局部組件,通過某個 Vue 實例/組件的實例選項 components 注冊僅在其作用域中可用的組件

var Child = {
		  template: '<div>A custom component!</div>'
		}
		var vm = new Vue({
			el: '#app',
			components:{
				'component-a':Child
			}
		})

局部注冊的組件 將只在父組件模板中可用

組件通信

組件 A 在它的模板中使用了組件 B,它們之間必然需要相互通信,父組件可能要給子組件下發數據,子組件則可能要將它內部發生的事情告知父組件
我們先來看一張圖

從圖上可以很清晰的看到,父子組件通信主要是使用prop和自定義事件,父組件通過 prop 給子組件下發數據,子組件通過事件給父組件發送消息。
父子組件的關系可以總結為 prop 向下傳遞,事件向上傳遞。

來看個示例:

<div id="app">
			 <div>
			 	接收到的子組件回復消息:{{replyMsg}}
			 </div>
			 <component-a v-bind:msg="msg" @reply="replay"></component-a>
		</div>
		<template id="componentA">
			<div>
				<div>我是組件a,接收到父類的消息是:{{msgfilter}}</div>
				<div @click="reply">回復</div>
			</div>
		</template>

Vue.component('component-a', {
		  template: '#componentA',
		  props:['msg'],
		  data:function(){
		  	return{
		  		msgfilter:'處理后的消息-》'+this.msg
		  	}
		  },
		  methods:{
		  	reply:function(){
		  		this.$emit('reply','子組件消息')
		  	}
		  }
		})
		var vm = new Vue({
			el: '#app',
			data:{
				msg:'父組件消息',
				replyMsg:''
			},
			methods:{
				replay:function(msg){
					this.replyMsg = msg
				}
			}
		})

需要注意的是,組件里面的data必須是一個函數,通過return形式返回

1.父組件下發數據到子組件

在組件中通過v-bind添加一個參數將數據傳遞到子組件里,然后使用props接收傳遞過來的參數props:['msg']
<component-a v-bind:msg="msg"></component-a>
渲染結果:

2.子組件通過事件給父組件發送消息
子組件通過$emit觸發事件

this.$emit('reply','子組件消息')

在組件標簽中通過v-on進行監聽

<component-a v-bind:msg="msg" @reply="replay"></component-a>

監聽到事件后觸發reply函數,接收到子組件發送的消息

replay:function(msg){
					this.replyMsg = msg
				}

渲染結果:

<div id="app">
	<div>
		接收到的子組件回復消息:子組件消息
	</div> 
	<div>
		<div>我是組件a,接收到父類的消息是:處理后的消息-》父組件消息</div> 
		<div>回復</div>
	</div>
</div>

以上可以看到我們是通過字符串數組來定義prop的,除此之外我們還可以用對象的形式來定義prop,用來為組件的 prop 指定驗證規則,
type的值可以是這些:String Number Boolean Function Object Array Symbol,例如:

      props: {
        name: String,
        showDialog: {
            type: Boolean,
            default: false
        }
      }

實現一個dialog對話框組件

<div id="app" class="main">
		<div v-text="isLogin?'注銷':'登錄'" @click="login">登錄</div>
		<div class="amount"><input type="tel" name="" v-model="amount"></div>
		<div class="btn_submit" @click="submit">確定</div>
		<v-dialog :show-dialog="showDialog" :msg="msg" :type="type" @close-dialog="closeDialog"></v-dialog>
	</div>
	<template id="dialog">
		<div class="dialog" v-if="showDialog">
			<div class="dialog_mask"></div>
			<div class="dialog_container">
				<div class="dialog_content">
					<div class="dialog_content_top" v-text="msg">提示內容</div>
					<div class="dialog_btn">
						<a v-if="type==1" href="javascript:;" class="btn" @click="close">確定</a>
						<a v-if="type==2" href="javascript:;" class="btn" @click="close">取消</a>
						<a v-if="type==2" href="javascript:;" class="btn" @click="login">去登錄</a>
					</div>
				</div>
			</div>
		</div>
	</template>

Vue.component('v-dialog', {
		    template: '#dialog',
		    // props:['msg','type','showDialog'],
		    props:{
		    	msg:String,
		    	type:Number,
		    	showDialog:{
		    		type: Boolean,
          			default: false
		    	}
		    },
		    data:function(){
                return {
                }
            },
            methods:{
            	close:function(){
            		// 觸發父類關閉窗口事件
            		this.$emit('close-dialog');
            	},
            	login:function(){
            		console.log("登錄跳轉中...");
            		this.$emit('close-dialog');
            	}
            }
		})
		// vue實例
		var vm = new Vue({
			el: '#app',
		  	data: {
		  		amount:'',
		  		msg:'',
		  		showDialog:false,
		  		type:1,// 提示類型  1單按鈕提示框  2雙按鈕提示框
		  		isLogin:true
			},
			methods:{
				login:function(){
					this.isLogin = !this.isLogin;
				},
				submit:function(){
					//彈出對話框組件
					if(!this.isLogin){//未登錄
						this.msg = "請先去登錄再領取金額";
						this.showDialog = !this.showDialog;
						this.type = 2;
						return;
					}
					if(this.amount){
						if(this.amount<1 || this.amount>1000){
							this.msg = "輸入金額不能低於1元大於1000";
							this.showDialog = !this.showDialog;
							this.type = 1;
						}else{
							this.msg = "領取成功,請在賬戶中心查看";
							this.showDialog = !this.showDialog;
							this.type = 1;
						}
					}else{
						this.msg = "領取金額不能為空";
						this.showDialog = !this.showDialog;
							this.type = 1;
					}
				},
				closeDialog:function(){//關閉對話框
					this.showDialog = false;
				}
			}
		})

總結

以上簡單介紹了vuejs的MVVM模型和它的雙向綁定機制,然后以一個helloworld示例開始了vuejs的使用,
之后又了解和熟悉了幾個比較常用的vue指令,綜合以上,構建了一個簡單的示例,最后講了vue中組件的一些
用法,父子組件是如何進行通信的,結合組件用法,實現了一個對話框組件。

作者:fozero
聲明:原創文章,轉載請注明出處,謝謝!http://www.cnblogs.com/fozero/p/8563939.html
標簽:vuejs


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM