vue組件實(shí)例解析
實(shí)現(xiàn)此例您可以學(xué)到:
- vue-cli的基本應(yīng)用
- 父組件如何向子組件傳遞值
- 單文件組件如何引入scss
- v-on和v-for的基礎(chǔ)應(yīng)用
- 源碼下載
一、搭建vue開發(fā)環(huán)境
1)更換鏡像到cnpm
npm install -g cnpm --registry=https://registry.npm.taobao.org
2)安裝vue-cli
cnpm install -g vue-cli
3)初始化vue項(xiàng)目
命令模式進(jìn)入項(xiàng)目所在的目錄,如d:\test\,輸入vue init 項(xiàng)目名稱即可。如果你想引入vue2.0框架,必須把nodejs、webpack和npm升級到最新版本。
4)node-sass和sass-loader實(shí)現(xiàn)scss的編譯
用cnpm安裝node-sass和sass-loader,用于編譯scss相關(guān)內(nèi)容。
5)通過npm install 安裝開發(fā)和運(yùn)行依賴組件
進(jìn)入剛創(chuàng)建好的目錄,執(zhí)行cnpm install安裝所有的開發(fā)和運(yùn)行依賴項(xiàng)
6)通過npm run dev支持調(diào)試版本
在安裝成功后,直接運(yùn)行npm run dev即可看到demo的運(yùn)行界面。
注意:
1.按照上述步驟搭建最終可以創(chuàng)建好vue項(xiàng)目,但也遇到幾個坑
2.安裝的nodejs和webpack、npm不是最新版本
二、實(shí)現(xiàn)Tag組件
學(xué)習(xí)一個新框架,首先是看文檔,最重要還是實(shí)踐。寫一個hello world過于簡單,要玩就玩?zhèn)€大的。我們就來實(shí)現(xiàn)一個Tag(標(biāo)簽)組件領(lǐng)悟一下vue的強(qiáng)大。
組件需求
- 將用戶輸入的標(biāo)簽信息動態(tài)的添加到標(biāo)簽列表區(qū)域。
- 同名和空標(biāo)簽不能輸入。
- 外部可以控制標(biāo)簽顯示區(qū)域的寬度。
實(shí)現(xiàn)思路
- 一個輸入框,用于接受標(biāo)簽內(nèi)容的輸入;
- 一個列表,用于展示所有輸入的標(biāo)簽信息;
- 提供一個可設(shè)置屬性,用于設(shè)置標(biāo)簽列表的寬度;
具體實(shí)現(xiàn)
1. 模板內(nèi)容代碼
<template>
<div class="tag-wrap">
<span>標(biāo)簽:</span>
<input type="text" id="tag" name="tag" v-model="val" />
<button id="apply" v-on:click="add" >添加</button>
<ul class="tag-cont clear" v-bind:style="{width: width}">
<li v-for="item in cont">{{item}}</li>
</ul>
</div>
</template>
1.1 template只是模板語言的標(biāo)記,解析后不會生成到頁面,所以內(nèi)容需要用一個div包裹?。?/p>
1.2 template中可以訪問Js代碼中data()和Methods、props等相關(guān)屬性;
1.3 props用于父組件向子組件傳遞值,此值可以動態(tài)傳遞;
1.4 v-on綁定事件,v-for用于迭代集合。
2. Js代碼
<script>
export default{
name: 'tag',
data () {
return {
cont: [],
val: ''
}
},
methods: {
add: function () {
let _val = this.val
if (_val.length === 0 || this.cont.indexOf(_val) > -1) {
return
}
this.cont.push(this.val)
}
},
props: {
width: {
type: String,
default: 'auto'
}
}
}
</script>
2.1 使用v-model="val"實(shí)現(xiàn)輸入自動更新val這個屬性;
2.2 add方法獲取val這個屬性的值,然后判斷是否為空,以及是否在已添加標(biāo)簽數(shù)據(jù)中存儲,如果不存在則添加到標(biāo)簽數(shù)組中。
2.3 props的width類型和默認(rèn)值,限制類型為String,默認(rèn)值為auto。
3. Scss代碼
<style lang='scss' scoped >
@keyframes item-show{
from{ opacity: 0; }
}
.clear{
zoom: 1;
}
.clear:after{
content: '';
display: block;
width: 0px;
height: 0px;
overflow: hidden;
clear: both;
}
$back-color:#fed;
span{
background: $back-color;
}
.tag-cont{
list-style: none;
margin: 10px auto;
padding: 5px;
border: 1px solid lightblue;
}
.tag-cont > li{
float: left;
padding: 5px;
border:1px solid gray;
border-radius: 10px;
animation: item-show 1s;
margin: 10px;
}
</style>
3.1 用lang來標(biāo)記style標(biāo)簽內(nèi)的Css實(shí)現(xiàn)
4. 在App.vue中引入Tag組件,并組件到Vue的Components(組件庫)中,然后在template中以標(biāo)簽的形式引用即可,代碼如下:
<template>
<div id="app">
<tag width="300px"></tag>
</div>
</template>
<script>
import Tag from './components/Tag'
export default {
name: 'app',
components: {
Tag
}
}
</script>
5. 效果圖

學(xué)習(xí)總結(jié)
Tag組件其實(shí)是一個很小的組件,業(yè)務(wù)價值很低,主要用于Vue新手入門。主要實(shí)現(xiàn)Vue常用的父組件改變子組件的值,view改變model,model的變化反應(yīng)到view上,事件的綁定等功能。
還需要繼承深入了解,以及vuex管理vue組件的應(yīng)用,還有組件之間的通信。
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
Vue實(shí)例初始化為渲染函數(shù)設(shè)置檢查源碼剖析
這篇文章主要為大家介紹了Vue實(shí)例初始化為渲染函數(shù)設(shè)置檢查源碼剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
詳談Object.defineProperty 及實(shí)現(xiàn)數(shù)據(jù)雙向綁定
這篇文章主要介紹了詳談Object.defineProperty 及實(shí)現(xiàn)數(shù)據(jù)雙向綁定,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
解決前端調(diào)用后端接口返回200但數(shù)據(jù)返回的是html標(biāo)簽
這篇文章主要給大家介紹了關(guān)于如何解決前端調(diào)用后端接口返回200但數(shù)據(jù)返回的是html標(biāo)簽的相關(guān)資料,文中通過圖文將解決的過程介紹的非常詳細(xì),對同樣遇到這個問題的朋友具有一定的參考解決價值,需要的朋友可以參考下2024-05-05
vue3配置全局參數(shù)(掛載全局方法)以及組件的使用
這篇文章主要介紹了vue3配置全局參數(shù)(掛載全局方法)以及組件的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07
Vue 2源碼解析HTMLParserOptions.start函數(shù)方法
這篇文章主要為大家介紹了Vue 2源碼解析HTMLParserOptions.start函數(shù)方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
Vue實(shí)現(xiàn)帶參數(shù)的自定義指令示例
這篇文章主要為大家介紹了Vue實(shí)現(xiàn)帶參數(shù)的自定義指令示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01

