国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

Vue.js最佳實踐(五招助你成為vuejs大師)

2024-05-06 15:34:39
字體:
來源:轉載
供稿:網友

本文面向對象是有一定Vue.js編程經驗的開發者。如果有人需要Vue.js入門系列的文章可以在評論區告訴我,有空就給你們寫。

對大部分人來說,掌握Vue.js基本的幾個API后就已經能夠正常地開發前端網站。但如果你想更加高效地使用Vue來開發,成為Vue.js大師,那下面我要傳授的這五招你一定得認真學習一下了。

第一招:化繁為簡的Watchers

場景還原:

created(){  this.fetchPostList()},watch: {  searchInputValue(){    this.fetchPostList()  }}

組件創建的時候我們獲取一次列表,同時監聽input框,每當發生變化的時候重新獲取一次篩選后的列表這個場景很常見,有沒有辦法優化一下呢?

招式解析:

首先,在watchers中,可以直接使用函數的字面量名稱;其次,聲明immediate:true表示創建組件時立馬執行一次。

watch: {  searchInputValue:{    handler: 'fetchPostList',    immediate: true  }}

第二招:一勞永逸的組件注冊

場景還原:

import BaseButton from './baseButton'import BaseIcon from './baseIcon'import BaseInput from './baseInput'export default { components: {  BaseButton,  BaseIcon,  BaseInput }}<BaseInput v-model="searchText" @keydown.enter="search"/><BaseButton @click="search"> <BaseIcon name="search"/></BaseButton>

我們寫了一堆基礎UI組件,然后每次我們需要使用這些組件的時候,都得先import,然后聲明components,很繁瑣!秉持能偷懶就偷懶的原則,我們要想辦法優化!

招式解析:

我們需要借助一下神器webpack,使用 require.context() 方法來創建自己的(模塊)上下文,從而實現自動動態require組件。這個方法需要3個參數:要搜索的文件夾目錄,是否還應該搜索它的子目錄,以及一個匹配文件的正則表達式。

我們在components文件夾添加一個叫global.js的文件,在這個文件里借助webpack動態將需要的基礎組件統統打包進來。

import Vue from 'vue'function capitalizeFirstLetter(string) { return string.charAt(0).toUpperCase() + string.slice(1)}const requireComponent = require.context( '.', false, //.vue$/  //找到components文件夾下以.vue命名的文件)requireComponent.keys().forEach(fileName => { const componentConfig = requireComponent(fileName) const componentName = capitalizeFirstLetter(  fileName.replace(/^/.///, '').replace(//./w+$/, '')  //因為得到的filename格式是: './baseButton.vue', 所以這里我們去掉頭和尾,只保留真正的文件名 ) Vue.component(componentName, componentConfig.default || componentConfig)})

最后我們在main.js中 import 'components/global.js' ,然后我們就可以隨時隨地使用這些基礎組件,無需手動引入了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 河南省| 九龙城区| 隆安县| 南昌县| 铜梁县| 阿拉善右旗| 孙吴县| 台湾省| 祥云县| 贵溪市| 平原县| 东兰县| 柘城县| 永德县| 化州市| 田东县| 安吉县| 玛纳斯县| 肇东市| 长沙市| 阜南县| 巴青县| 中超| 青川县| 尼勒克县| 河曲县| 叙永县| 姚安县| 泸定县| 冷水江市| 曲靖市| 华坪县| 勃利县| 江阴市| 西吉县| 青阳县| 缙云县| 乌拉特前旗| 隆尧县| 永清县| 景宁|