成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

vue 項(xiàng)目開發(fā)要點(diǎn)總結(jié)

Drummor / 3033人閱讀

摘要:提交是更改狀態(tài)的唯一方法,并且這個過程是同步的。對于大型應(yīng)用,我們會希望把相關(guān)代碼分割到模塊中。

vue-cli 腳手架工具的使用

vue-cli 的依賴

vue-cli 的使用流程

node 的安裝
node 是通過js 操作系統(tǒng)接口的語言; npm 是node的包管理工具;所以,安裝了node 就可以直接使用npm 下載我們需要的包;
node 可以直接去node官網(wǎng)下載對應(yīng)系統(tǒng)的安裝包,安裝提示完成;
然后在 命令行中 通過 npm -v 查看npm 版本,如果有出來代表安裝成功;

npm 代理 到cnpm
你直接通過添加 npm 參數(shù) alias 一個新命令:

alias cnpm="npm --registry=https://registry.npm.taobao.org 
--cache=$HOME/.npm/.cache/cnpm 
--disturl=https://npm.taobao.org/dist 
--userconfig=$HOME/.cnpmrc"

然后運(yùn)行

cnpm  install xx -g  //全局安裝xx

使用 vue-cli

vue init webpack demoName //生成 webpack 為模板的vue項(xiàng)目

運(yùn)行熱更新頁面

npm run dev

生成項(xiàng)目可以直接通過 http://localhost:8080/?#/ 訪問

如果你是拉別人的項(xiàng)目運(yùn)行的,要先運(yùn)行下面的命令,安裝依賴包

npm install 
//或者
npm i

生成一個 靜態(tài)項(xiàng)目文件(直接打開的靜態(tài)頁面)

npm run build
大多數(shù)情況 ,生成的頁面是不可以直接打開的;提示只能部署到 服務(wù)器上才能正常訪問;
如果需要直接本地打開;到項(xiàng)目目錄下的config文件夾里的index.js文件中,將build對象下的assetsPublicPath中的“/”,改為“./”即可


生成的文件都是經(jīng)過壓縮的,帶md5的文件

es6 的引入與輸出
export default{} ,  module.exports = {},  exports { }

在node 的模塊中,exports 是 module.exports 的引用;但是在vue 中 不能寫成

exports = {
    porps:["text"]
}

// 提示 text 未定義;

exports default {} 定義的輸出;可以通過 import xx 直接使用(標(biāo)準(zhǔn)ES6);寫法是:

exports default {a:123}    

import a; 

module.exports = {} 與 exports default 是等價(jià)的

但是如果 同一個js 同時(shí)出現(xiàn) module.exports ={} 和 import 就會報(bào)錯

module.exports = {a:123} //定義和導(dǎo)出

import a;  //引入

//上面兩個關(guān)鍵詞 不能同時(shí)出現(xiàn)在同一個js 中

報(bào)錯原因如下:

webpack可以使用require和export ,但是不能混合使用import 和module.exports ,不然會報(bào)錯Cannot
assign to read only property "exports" of object "#"
ES6 統(tǒng)一的寫法 是 import 和 exports default
如果你要import 組件 ;建議 統(tǒng)一使用 exports default {} 編寫組件

vue-router 路由插件安裝

安裝

cnpm install vue-router 

引入為全局插件

配置路由表

可以通過router-link 組件 鏈接到 對應(yīng)組件;它會解析成類似a 標(biāo)簽

forms  //注意書寫格式一定要正確
father

注意到 生成的url 中前面自動加了個 “#”;可以通過添加 mode:"history", 去掉

原理:https://router.vuejs.org/zh-c...

路由配置中,path 可以設(shè)置 url 帶參;

帶參path定義

表示 apple 后面跟的是參數(shù),不是路徑;

帶參路徑

獲取參數(shù)

使用路由要注意的地方

所有的路由都是定義在 routes 生成的頁面中的;不能在子組件中重新定義;例子如下:

var router = new VueRouter()

import browseMode from "./components/browse-mode.vue"
import blogList from "./components/blog-list.vue"
import blogArticle from "./components/blog-article.vue"
import writePanel from "./components/write-panel.vue"

router.map({
    "/": {
      component: browseMode,
      subRoutes: {
        "/": {
          component: blogList
        },
        "/details/:artId": {
          component: blogArticle
        }
      }
    },
    "/edit/:mode": {
      component: writePanel
    },
    "/search/tag/:tag": {
      component: browseMode,
      subRoutes: {
        "/": {
          component: blogList
        }
      }
    },
    "/search/time/:time": {
      component: browseMode,
      subRoutes: {
        "/": {
          component: blogList
        }
      }
    },
    "/search/title/:title": {
      component: browseMode,
      subRoutes: {
        "/": {
          component: blogList
        }
      }
    },
})
router.start(App, "app")

路由不是最適合做tab切換的;最適合做tab的是 components 內(nèi)置組件 ;通過is 控制切換;



var vm = new Vue({
  el: "#example",
  data: {
    currentView: "home" //改變這個值就會切換內(nèi)容;
  },
  components: {
    home: { /* ... */ },
    posts: { /* ... */ },
    archive: { /* ... */ }
  }
})

定義帶參路由 的時(shí)候 注意格式是 path:"/box1/:text", 不是path:"/box1:text",(可以理解為/: 后面是參數(shù) ,/后面是路徑;)

定義好路由后, router-link 是可以放在任何地方的;它就是一個a標(biāo)簽;點(diǎn)擊會切換第一個父級的router-view 中的頁面;還要注意格式和傳參

 
  • box1
  • // to的 值是一個對象 ,key 固定是path ,value 是 一個字符串; // 后面的666 是參數(shù);它的前面不是 “ ?或者 & ” 而是 “ / ”;

    獲取參數(shù)的時(shí)候,直接去到參數(shù)的值是 this.$route.params.text (text是你定義路由時(shí)的 :text )

    因?yàn)?route 是一個全局變量,你還可以直接在html 中使用它的url參數(shù)

    {{$route.params.text}}

    定義一個多參數(shù) 路由的 url

    使用時(shí)的url可能是這樣:

    http://localhost:8080/#/apple/red/detail/fool
    //后面的detail 是固定的。

    獲取的方法是一樣的;

    var a = $route.params;
    
    //結(jié)果
    a={
        color:red,
        type:fool
    }
    子路由的定義
    {
      path:"/box1",
      component:box1,
      children:[
        {
          // 當(dāng) /box1/box1a匹配成功,
          // box1a會被渲染在 box1的  中
          path:"box1a", //這里不加 “ / ”
          component:box1a
        },
        {
          path:"box1b",
          component:box1b
        }
      ]
    },
    // 要注意,以 / 開頭的嵌套路徑會被當(dāng)作根路徑。 這讓你充分的使用嵌套組件而無須設(shè)置嵌套的路徑。
    
    
    
    //在box1 中定義一行 
    
    
    
    //子組件 box1a 會自動渲染 到頁面中;
    
    //如果添加兩個 router-link 組件 就可以做tab切換(不建議用路由做tab)
    //router-link 只會切換 第一個父級的 router-view 中的內(nèi)容,所以不會刷新整個 box1 ;
    
    
    • box1a
    • box1b
    //path 寫成 /box1/box1a 是用了根路徑(絕對路徑)的形式; //如果寫成 {path:"box1a"} 則是相對路徑;這樣寫點(diǎn)擊 瀏覽器的url會寫成 http://localhost:8080/box1a //因?yàn)轫敿壜酚芍惺菦]有定義 box1a 組件的;所以頁面空白;
    帶參子路由
    //路由定義
    {
      path:"/box1/:text",
      component:box1,
      children:[
        {
          path:"box1a",
          component:box1a
        },
        {
          path:"box1b",
          component:box1b
        }
      ]
    },
    
    
    //跳轉(zhuǎn)到 box1 的寫法
     
  • box1
  • //box1 中渲染 box1a/b 的寫法
    • box1a
    • box1b
    //初始化的時(shí)候生成url mounted: function () { this.parms = this.$route.params.text; this.url1 = "/box1/"+this.parms+"/box1a" this.url2 = "/box1/"+this.parms+"/box1b" },

    router-link 中的to 屬性,如果只是簡單的跳轉(zhuǎn)可以直接寫成 to=“box1”;

    如果加上:綁定屬性;后面的屬性可以是簡短的 表達(dá)式,因此上面的例子可以簡化為:

    //路由定義
    {
      path:"/box1/:text",
      component:box1,
      children:[
        {
          path:"box1a",
          component:box1a
        },
        {
          path:"box1b",
          component:box1b
        }
      ]
    },
    
    
    //跳轉(zhuǎn)到 box1 的寫法
     
  • box1
  • //box1 中渲染 box1a/ b 的寫法 //to 屬性會自動 運(yùn)算出來;
    • box1a
    • box1b
    //初始化的時(shí)候生成url mounted: function () { this.parms = this.$route.params.text; },
    具名路由

    router-link 還可以通過 name 指定跳轉(zhuǎn)(具名路由);通過例如 tag="li" 指定包裹標(biāo)簽為a以為的tag;

     children:[
            {
              path:"box1a",
              name:"nameBox",
              component:box1a
            }
            ]
            
     nameBox       
            
    //結(jié)果:會生成li, 點(diǎn)擊router-view 會渲染出 box1a ;注意,path是不可缺少的
            
    用具名路由布局(代替iframe的方式)
    export default new Router({
      mode:"history",
      routes: [
        {
          path:"/index",
          components:{   //注意這里是有 “ s ” 的
            default:vuexIndex,  //對應(yīng) 
            left:vuexLeft,    // 對應(yīng)
            right:vuexRight  //對應(yīng)
          }
        }
      ]
    })
    
    
    
    
    //注意訪問的路徑 是在components 中定義的path ;
    
    在某個頁面中定義具名路由
    {
      path:"/layout",
      name:"layout",
      component:layout,
      children: [
        {
          path: "/",
          components:{
            default:main,
            leftView:leftView,
            topBar:topBar
          },
        }
      ]
    }
    
    
    
    
    
    路由的重定向
     routes: [
        { path:"/", redirect:"/box" //路徑不存在就跳轉(zhuǎn)到box
        },
        { path: "/a", redirect: "/b" } //訪問a的路徑,都跳轉(zhuǎn)到b
    ]
    vuex 狀態(tài)管理插件安裝

    當(dāng)vue項(xiàng)目中 組件過多并設(shè)計(jì)到功能某些數(shù)據(jù)的時(shí)候,管理數(shù)據(jù)變得復(fù)雜,VUEX 就是通過自身的一套數(shù)據(jù)管理流程幫助你管理 項(xiàng)目數(shù)據(jù)(狀態(tài));

    安裝

    cnpm install vuex --save

    實(shí)例化

    //在main.js 中
    
    import Vuex from "vuex"
    
    Vue.use(Vuex);
    let store = new Vuex.Store({  //Store 是vuex 方法
      state:{ //存放變量的地方
        total:0,
        appleTotal:0,
        bananaTotal:0,
      },
      mutations:{     //定義同步變量的方法
        aSetValue(state,value){
          state.appleTotal = value
          state.total = state.appleTotal + state.bananaTotal;
        },
        bSetValue(state,value){
          state.bananaTotal = value
          state.total = state.appleTotal + state.bananaTotal;
        }
      }
    })
    
    
    new Vue({
      el: "#app",
      store,   //在實(shí)例中 引入
      router,
      components: { App },
      template: ""
    })
    

    獲取值

    vuex 的變量store 全局以后可以通過以下語句獲取

    this.$Store.state.total 
    
    //組件中
     

    總價(jià):{{$store.state.total}}

    還可以通過設(shè)置getter函數(shù) 暴露對應(yīng)的值

     getters:{
        getTotal(state){
          return state.total
        }
      },
    
    //組件中
    
    

    總價(jià):{{$store.getters.getTotal}}

    改變vuex變量的值

    通過在組件中調(diào)用以下特定語句改變

     methods:{
          add(){
            this.cnt += 1;
            //bSetValue 是在vuex實(shí)例的mutations中定義的方法
            //通過 bSetValue方法 去改變實(shí)例的值
            this.$store.commit("bSetValue",this.cnt*5) 
          },
          minus(){
            this.cnt-=1;
            this.$store.commit("bSetValue",this.cnt*5)
          }
        },
        
     // 在vuex 中只有 commit 方法可以改變數(shù)據(jù);這里是不建議直接在組件中調(diào)用 cmmit 的
     // 因?yàn)閏mmit中只能是同步操作;但是交互往往需要同步數(shù)據(jù)庫
     // 更加好的方法是在 actions的方法 中觸發(fā) commit;actions 方法支持異步操作;
     // 所有涉及 后端API 的接口都是放在actions 中進(jìn)行   

    actions 屬性

    mutations:{
            aSetValue(state,value){
              state.appleTotal = value
              state.total = state.appleTotal + state.bananaTotal;
            },
            bSetValue(state,value){
              state.bananaTotal = value
              state.total = state.appleTotal + state.bananaTotal;
            }
      },
    actions:{ 
             // 定義doAfn 方法,間接觸發(fā) aSetValue;
             // 在doAfn 方法是可以用ajax 的
            doAfn(context,price){
              context.commit("aSetValue",price)
            },
            doBfn(context,price){
              context.commit("bSetValue",price)
            }
      }
    

    組件中的觸發(fā)方式 通過 dispatch 觸發(fā)doAfn;

    this.$store.dispatch("doAfn",val*10)
    vuex 的 modules

    Vuex 允許我們將 store 分割成模塊(module)。每個模塊擁有自己的 state、mutation、action、getter、甚至是嵌套子模塊——從上至下進(jìn)行同樣方式的分割:

    官方文檔代碼

    const moduleA = {
      state: { ... },
      mutations: { ... },
      actions: { ... },
      getters: { ... }
    }
    
    const moduleB = {
      state: { ... },
      mutations: { ... },
      actions: { ... }
    }
    
    const store = new Vuex.Store({
      modules: {
        a: moduleA,
        b: moduleB
      }
    })
    
    store.state.a // -> moduleA 的狀態(tài)
    store.state.b // -> moduleB 的狀態(tài)

    官方的文檔組織建議:

    應(yīng)用層級的狀態(tài)應(yīng)該集中到單個 store 對象中。

    提交 mutation 是更改狀態(tài)的唯一方法,并且這個過程是同步的。

    異步邏輯都應(yīng)該封裝到 action 里面。

    對于大型應(yīng)用,我們會希望把 Vuex 相關(guān)代碼分割到模塊中。下面是項(xiàng)目結(jié)構(gòu)示例:

    ├── index.html
    ├── main.js
    ├── api
    │   └── ... # 抽取出API請求
    ├── components
    │   ├── App.vue
    │   └── ...
    └── store
        ├── index.js          # 我們組裝模塊并導(dǎo)出 store 的地方
        ├── actions.js        # 根級別的 action
        ├── mutations.js      # 根級別的 mutation
        └── modules
            ├── cart.js       # 購物車模塊
            └── products.js   # 產(chǎn)品模塊

    https://vuex.vuejs.org/zh-cn/...

    一個 vuex 小例子

    父組件
    
    
    
    
    apple 組件
    
    
    
    
    banana 組件
    
    
    
    
    main.js
    // The Vue build version to load with the `import` command
    // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
    import Vue from "vue"
    import Vuex from "vuex"
    import App from "./App"
    import router from "./router"
    
    
    Vue.config.productionTip = false
    
    Vue.use(Vuex);
    let store = new Vuex.Store({
      state:{
        total:0,
        appleTotal:0,
        bananaTotal:0,
      },
      getters:{
        getTotal(state){
          return state.total
        }
      },
      mutations:{
        aSetValue(state,value){
          state.appleTotal = value
          state.total = state.appleTotal + state.bananaTotal;
        },
        bSetValue(state,value){
          state.bananaTotal = value
          state.total = state.appleTotal + state.bananaTotal;
        }
      },
      actions:{
        doAfn(context,price){
          context.commit("aSetValue",price)
        },
        doBfn(context,price){
          context.commit("bSetValue",price)
        }
      }
    })
    
    
    
    /* eslint-disable no-new */
    new Vue({
      el: "#app",
      store,
      router,
      components: { App },
      template: ""
    })
    

    文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

    轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/92520.html

    相關(guān)文章

    • vue 項(xiàng)目要點(diǎn)總結(jié)(二)

      摘要:靜態(tài)圖片怎么引入對重復(fù)元素的遍歷產(chǎn)品數(shù)據(jù)統(tǒng)計(jì)數(shù)據(jù)預(yù)測流量分析廣告發(fā)布在重復(fù)的部分用如果某個重復(fù)的部分比較分散可用循環(huán),循環(huán)是從標(biāo)簽本身就開始的既是的載體,也是與同一個標(biāo)簽的靈活使用遍歷的時(shí)候可以接受幾種賦值方式直接綁定的屬性 靜態(tài)logo圖片怎么引入 showImg(https://segmentfault.com/img/bV2iRj?w=350&h=163); 對重復(fù)元素...

      liuhh 評論0 收藏0
    • 記一次前端項(xiàng)目重構(gòu)要點(diǎn)總結(jié)

      摘要:重構(gòu)總共耗時(shí)個工作日。第一個重構(gòu)原因就是沒有引入靜態(tài)類型,導(dǎo)致查看一個對象結(jié)構(gòu)需要翻來覆去在多個文件中查找。第三是各個狀態(tài)模塊耦合度高,加大了代碼維護(hù)難度。但如果耦合度過高,往往是因?yàn)槟K沒有細(xì)分到位。這個項(xiàng)目也不列外。 showImg(https://segmentfault.com/img/remote/1460000019660483); 不知不覺已是2019年的7月,恍惚之間已...

      frolc 評論0 收藏0
    • Vue下滾動到頁面底部無限加載數(shù)據(jù)Demo

      摘要:下滾動到頁面底部無限加載數(shù)據(jù)看到一篇覺得挺實(shí)用的就看了下順便簡單翻譯了一下給需要的人參考從這個項(xiàng)目中可以加深對的生命周期的理解何時(shí)開始請求如何結(jié)合使用原生來寫事件等等我這里主要是對原文的重點(diǎn)提取和補(bǔ)充本文技術(shù)要點(diǎn)生命周期簡單用法格式化日期圖 Vue下滾動到頁面底部無限加載數(shù)據(jù)Demo 看到一篇Implementing an Infinite Scroll with Vue.js, 覺得...

      elarity 評論0 收藏0
    • 重學(xué)前端學(xué)習(xí)筆記(一)--前端發(fā)展史以及學(xué)習(xí)痛點(diǎn)

      摘要:筆記說明重學(xué)前端是程劭非前手機(jī)淘寶前端負(fù)責(zé)人在極客時(shí)間開的一個專欄,每天分鐘,重構(gòu)你的前端知識體系,筆者主要整理學(xué)習(xí)過程的一些要點(diǎn)筆記以及感悟,完整的可以加入的專欄學(xué)習(xí)原文有的語音,如有侵權(quán)請聯(lián)系我,郵箱。 筆記說明 重學(xué)前端是程劭非(winter)【前手機(jī)淘寶前端負(fù)責(zé)人】在極客時(shí)間開的一個專欄,每天10分鐘,重構(gòu)你的前端知識體系,筆者主要整理學(xué)習(xí)過程的一些要點(diǎn)筆記以及感悟,完整的可以...

      hlcfan 評論0 收藏0
    • 重學(xué)前端學(xué)習(xí)筆記(一)--前端發(fā)展史以及學(xué)習(xí)痛點(diǎn)

      摘要:筆記說明重學(xué)前端是程劭非前手機(jī)淘寶前端負(fù)責(zé)人在極客時(shí)間開的一個專欄,每天分鐘,重構(gòu)你的前端知識體系,筆者主要整理學(xué)習(xí)過程的一些要點(diǎn)筆記以及感悟,完整的可以加入的專欄學(xué)習(xí)原文有的語音,如有侵權(quán)請聯(lián)系我,郵箱。 筆記說明 重學(xué)前端是程劭非(winter)【前手機(jī)淘寶前端負(fù)責(zé)人】在極客時(shí)間開的一個專欄,每天10分鐘,重構(gòu)你的前端知識體系,筆者主要整理學(xué)習(xí)過程的一些要點(diǎn)筆記以及感悟,完整的可以...

      wayneli 評論0 收藏0

    發(fā)表評論

    0條評論

    閱讀需要支付1元查看
    <