国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

vue 基礎(chǔ)

fasss / 569人閱讀

摘要:依的值,來決定哪個組件被渲染。不具名的內(nèi)容會替換子組件中我是默認(rèn)內(nèi)容的默認(rèn)內(nèi)容另一個主要段落。這里是一些聯(lián)系信息渲染結(jié)果為這里可能是一個頁面標(biāo)題主要內(nèi)容的一個段落。

vue腳手架頁面是怎么生成的? (組件注冊,路由插件的使用);

主要涉及的文件:

index.html
index.js
main.js
APP.vue

大致的過程就是:

main.js 通過

import Vue from "vue"
import App from "./App"
import router from "./router"

引入主要的文件;并通過下面的代碼,初始化 vue 視圖,掛載到 index.html 的id = "app" 的節(jié)點中(根節(jié)點);

new Vue({
  el: "#app",
  router,
  template: "",
  components: { App }
})

router :引用 router 路由插件,它會運行 router文件夾下的 index.js

components: { App } 的意思就是 注冊APP.vue 作為子組件;

template: "" 的意思就是掛在名為App的子組件到 根節(jié)點;它其實是重寫了 根節(jié)點 的所有內(nèi)容;

 "" 其實是  的縮寫;所以template 還可以寫成: 
 
 template: "
文字
", //這就跟 在普通vue文件中插入 子組件 一樣了

這個頁面的幾個“App ”的依賴關(guān)系是:

import App from "./App" 引入了 App.vue 組件 (相當(dāng)于聲明并賦值了App變量) 
components: { App } 在實例中 注冊上面的 App子組件;
template: "" 使用 這個組件替換實例的根節(jié)點內(nèi)容

index.html部分已經(jīng)搞定,那么看一下被使用作為的根節(jié)點App.vue 文件中發(fā)生了什么:
它除了常規(guī)的html 和css 代碼;還有一句



//它相當(dāng)于

它的意思是說,當(dāng)前位置 引入 router 路由插件引導(dǎo)的子組件;

最后,看一下router 引入了什么: 那就是router文件夾下 index.js 的內(nèi)容:

import forms from "@/components/form.vue" // 把form.vue 子組件引入


export default new Router({  //新建路由,并輸出
  routes: [
    {
      path: "/",        //路由重定向的路徑寫法
      component: forms    //組件為forms
    }
  ]
})

可以看到,router 的 index.js 把你編寫的子組件 form.vue 作為子組件 并重定向為默認(rèn)子組件
這樣 App.vue 的 就會找到 form.vue 渲染出來;

組件的定義,注冊 與 使用

1,全局組件:

2,局部組件
通過父組件的 components 屬性注冊;

通俗來說就是 :vue 的文檔樹 是通過組件的方式組織的; 每個組件可以成為其它組件的子組件(只需要引入);
每個組件都有
template: 組件的html 結(jié)構(gòu);
components :注冊或者定義 該組件的要使用的子組件;

3 組件樹實例代碼

效果:

組件的data 為什么 都是這樣的方?:

data:function (){
    reture {
        a:1,
        b:2
    }
}

因為 當(dāng)這個組件被引用的時候,我們希望每次引用都是獨立的;而不是改變其中一個,全部改變;這樣reture 相當(dāng)于復(fù)制的一個新的對象存儲數(shù)據(jù);

內(nèi)置組件

component 渲染一個“元組件”為動態(tài)組件。依 is 的值,來決定哪個組件被渲染。

 

var vm = new Vue({
  el: "#example",
  data: {
    currentView: "home"
  },
  components: {
    home: { /* ... */ },
    posts: { /* ... */ },
    archive: { /* ... */ }
  }
})

當(dāng)你同一位置有多個組件切換的時候,可能需要用到 內(nèi)置組件控制;通過is 綁定 變量z 控制顯示哪個變量;
常用場景 tab 切換;

緩存組件

通過keep-alive 內(nèi)置組件 讓瀏覽器 緩存 你的組件

 
    

hello

transition 是過渡動畫組件; 例子中 p元素通過 變量 show 控制顯示隱藏; 配合自定義的css 動畫 fade 顯示過渡效果;

過渡動畫執(zhí)行過程 有幾個狀態(tài),可以通過css 為這些狀態(tài)自定義樣式

.fade-enter-active, .fade-leave-active { //顯示和隱藏兩個動作的過渡期 透明度都是0.5
  transition: opacity .5s
}
.fade-enter, .fade-leave-to /* .fade-leave-active 在低于版本 2.1.8 中 */ {
  opacity: 0
} //顯示動作開始時 和 隱藏動作結(jié)束時 的透明度都是 0;

動畫組件還為幾個 過渡 提供鉤子

  //在離開動作完成后執(zhí)行 transitionComplete方法
    
toggled content

除了 after-enter 外還有多個 鉤子函數(shù)

slot 內(nèi)容分發(fā)組件;
顧名思義 就是通過slot組件去定制 子組件的 某些 需要自定義的顯示內(nèi)容; 這里的內(nèi)容不只是變量;還包括html;它主要靠 屬性 name 去對應(yīng) 內(nèi)容

(官方例子)
假定我們有一個 app-layout 組件,它的模板為:

我是默認(rèn)內(nèi)容 //當(dāng)沒有傳入內(nèi)容是 ;默認(rèn)內(nèi)容會被展示

父組件模板:


  

這里可能是一個頁面標(biāo)題

//具名slot 會根據(jù)名字 找到子組件中對應(yīng)位置插入

主要內(nèi)容的一個段落。

//不具名的 內(nèi)容 會替換 子組件中我是默認(rèn)內(nèi)容 的默認(rèn)內(nèi)容

另一個主要段落。

這里是一些聯(lián)系信息

渲染結(jié)果為:

這里可能是一個頁面標(biāo)題

主要內(nèi)容的一個段落。

另一個主要段落。

這里是一些聯(lián)系信息

v-bind 與 class 的應(yīng)用

v-bind簡寫 為 " : " 用它來綁定元素的 屬性; 例如title ,name,class,自定屬性等;它綁定 class非常靈活

1. v-bind:class 與 本身的class 不會沖突;

data:function(){ reture { a: "red" } } //結(jié)果是:

2. data 可以是對象;value 的bool 值代表是否渲染此class

data:function(){ reture { a:{ red:true, bold: true, padding:false } } } //結(jié)果是:

3. data 可以是數(shù)組;

data:function(){ reture { a:["red","buld"] } } //結(jié)果是:

4.data 是數(shù)組對象的混合

data:function(){ reture { a:["red",{blue:false,padding:true}] } } //結(jié)果是:
vue 的條件判斷

vue 主要通過 v-if 和 v-show ,v-else 控制模板的渲染流程

他們的區(qū)別是: 如果a==false; v-if 是不會渲染 box 的,就是dom中找不到 box;v-show則只會把box 設(shè)置為 display:none;

v-else 會對應(yīng)最近的一個 v-show 或者 v-if 做渲染;它不需要變量;

事件修飾器 實現(xiàn) 按enter 的時候 執(zhí)行搜索

//或者
自定義事件 ——父子組件的信息傳遞

子 傳給 父

//父組件:


compononet
methods:{
    doSome (str){
        console.log(str)
    }
}

//子組件


methods:{
    saySome(){
        this.$emit("myEvent","123")
    }
}



//結(jié)果 點擊子組件的button 后;輸出 123

父 傳給 子

//父組件

我是父親{{fatherName}}

//或者動態(tài)綁定這個值 data:(){ return { fatherName:"百麗" } } //子組件 "my-child":{ template:"

我是{{num}}兒子

", props:["num"] }

結(jié)果:

或者

props 屬性可以寫成 對象的形式

props:{
    num:["string","Number"] //表示只接受 字符串或者數(shù)字類型的值;
}
表單元素的使用

表單的數(shù)綁定 用到 v-model
input


{{a}}
data:function(){ reture { a:"" } } // 在輸入框中輸入值,就會賦值到 變量a 同時 div 的內(nèi)容也會是a ; // 數(shù)據(jù)的回填 只需要給 a 賦值就可以

checBox




{{arr}}
data:function(){ reture { arr:[] } } // 被選中的 checBox 它的值會被打印 成為arr 的一個元素 // 回填操作;只要給 arr 填入 元素;元素對應(yīng)的checbox 就會被選中;例如: data:function(){ reture { arr:["a"] // value=="a" 的 checBox 會被選中 } }

select


//通過 arr2 渲染出 option;
//這里的 value 前面一定要加 “:” 否則會把item.value當(dāng)做普通字符串渲染

data:function(){
    reture {
       arr2:[
                {
                  value:"10",
                  name:"banana"
                },
                {
                  value:"2",
                  name:"apple"
                }
            ],
       selection:null
    }
}
 methods:{
    dod(){
        console.log(this.selection)
    }
}

// 通過為select 綁定 dod方法和綁定selection值  change事件發(fā)生時輸出當(dāng)前選中值;
// 回填,只要給selection 賦值;對應(yīng)的項就會默認(rèn)選中

總結(jié):雙向綁定自動完成視圖更新;改變data 就會有視圖結(jié)果;回填表單,單選的 回填值是字符串;多選的對應(yīng)值是數(shù)組;

計算屬性 與 監(jiān)聽屬性

計算屬性


{{computerD}}

data:function(){
    reture {
       d:""
    }
}
computed:{
    computerD(){
        return this.d.replace(/d/g,"") 
    }
}

//結(jié)果: 在表單輸入的值 會被刪除數(shù)字 剩下文字輸出到頁面;

監(jiān)聽屬性 主要應(yīng)用于 只要x改變 就做處理 的情況;


{{mode}}

data:function(){
    reture {
       d:"",
       mode:""
    }
}
watch:{
    d(val,old){
        this.mode = "新值:"+val+" 舊值: "+old
    }
}
//結(jié)果: 每當(dāng)d 改變時 ;mode 也改變;
自定義指令

vue 通過 directives 自定義指令

directives:{ color:function(el,binging){ //color 對應(yīng) v-color 指令; 處理函數(shù)有兩個參數(shù),el代表綁定的元 el.style.color = binging.value; //素,binging 代表指令的值; } }

全局自定義指令 只要 在main.js 中定義指令,這個指令就會被全局使用;本質(zhì)上就是,在new.Vue() 實例化 vue實例的時候,掛載在根節(jié)點 的時候 定義指令 為全局指令;

自定義指令 的分時段執(zhí)行;

這時 color 的寫法會有不同;color 變成了對象;每個時期對應(yīng)為key,value是fn;

應(yīng)用場景:表單渲染完成以后,focus 到某個input




directives:{
    focus:{
        inserted:function(el,binging){ //在插入完成后 執(zhí)行
            el.focus();
        }
    }
}
vue 插件的安裝與使用

插件是什么? 可以理解為 一個功能豐富的vue 組件;

可以在package.json 中找到所有注冊的插件

插件安裝
在 命令行輸入 npm install xxx --save 把插件安裝到 項目,并且通過--save 寫入到package.json中

這樣別人通過 package.json 就可以安裝我們的項目依賴插件;

引入到文件

引入到 實例中

引入組件中的 @ 是什么東西

它是一個自定義命令;在webpack 中做了定義,意思是@補充路徑為絕對路徑;

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

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/92410.html

相關(guān)文章

  • (原創(chuàng))vue 學(xué)習(xí)筆記

    摘要:菜鳥教程這是一個屬性其值是字符串菜鳥教程同上這是一個屬性其值是字符串用于定義的函數(shù),可以通過來返回函數(shù)值。它們都有前綴,以便與用戶定義的屬性區(qū)分開來。 開篇語 我最近學(xué)習(xí)了js,取得進步,現(xiàn)在學(xué)習(xí)vue.js.建議新手學(xué)習(xí),請不要用npm的方式(vue-cli,vue腳手架),太復(fù)雜了. 請直接下載vue.js文件本地引入,就上手學(xué)習(xí)吧參照菜鳥教程網(wǎng)站的vue.js教程http://...

    layman 評論0 收藏0
  • Java學(xué)習(xí)路線總結(jié),搬磚工逆襲Java架構(gòu)師(全網(wǎng)最強)

    摘要:哪吒社區(qū)技能樹打卡打卡貼函數(shù)式接口簡介領(lǐng)域優(yōu)質(zhì)創(chuàng)作者哪吒公眾號作者架構(gòu)師奮斗者掃描主頁左側(cè)二維碼,加入群聊,一起學(xué)習(xí)一起進步歡迎點贊收藏留言前情提要無意間聽到領(lǐng)導(dǎo)們的談話,現(xiàn)在公司的現(xiàn)狀是碼農(nóng)太多,但能獨立帶隊的人太少,簡而言之,不缺干 ? 哪吒社區(qū)Java技能樹打卡?【打卡貼 day2...

    Scorpion 評論0 收藏0
  • Laravel 和 Vue 的項目搭建:基礎(chǔ)

    摘要:此項目前端使用框架,加上這些常用擴展后的其中還加入了加載器解析工具前端動畫等,不需要的可以自行刪除。沒有的,需要設(shè)置淘寶鏡像,下載的是國外的鏡像,速度慢而且可能出現(xiàn)下載失敗的問題。 本篇只是實現(xiàn)了 基礎(chǔ) 的功能,對于實際的項目中的權(quán)限等還未涉及,這些會在后期逐步完善。相關(guān)項目 laravel-vue-iview 的 GitHub 地址 戳這里,此項目基本可用于實際開發(fā)工作。 Lara...

    jiekechoo 評論0 收藏0
  • vue1.x 基礎(chǔ)使用(一)

    摘要:最近項目進度慢下來了,花點時間總結(jié)一下。文章會從到的一些說明以及使用,也會文章中的代碼共享出來。詳細(xì)請關(guān)注后續(xù)。后面陸續(xù)會換到其他的一些工具,如,等。也會介紹一些常用的工具。如下一代的語法編譯器,的路由,的交互。 最近項目進度慢下來了,花點時間總結(jié)一下。文章會從vue1.x 到2.x的一些說明以及使用,也會文章中的代碼共享出來。詳細(xì)請關(guān)注后續(xù)。 簡介:感慨是會用到一些第三方的模塊下載工...

    xuexiangjys 評論0 收藏0
  • vue1.x 基礎(chǔ)使用(一)

    摘要:最近項目進度慢下來了,花點時間總結(jié)一下。文章會從到的一些說明以及使用,也會文章中的代碼共享出來。詳細(xì)請關(guān)注后續(xù)。后面陸續(xù)會換到其他的一些工具,如,等。也會介紹一些常用的工具。如下一代的語法編譯器,的路由,的交互。 最近項目進度慢下來了,花點時間總結(jié)一下。文章會從vue1.x 到2.x的一些說明以及使用,也會文章中的代碼共享出來。詳細(xì)請關(guān)注后續(xù)。 簡介:感慨是會用到一些第三方的模塊下載工...

    pkhope 評論0 收藏0
  • Vue基礎(chǔ)

    摘要:基礎(chǔ)安裝命令行工具提供一個官方命令行工具,可用于快速搭建大型單頁應(yīng)用。打開瀏覽器的控制臺,并修改。自定義指令聚焦元素當(dāng)頁面加載時,元素將獲得焦點注意在移動版上不工作。現(xiàn)在讓我們完善這個指令注冊一個全局自定義指令當(dāng)綁定元素插入到中。 Vue基礎(chǔ) 安裝vue npm install vue 命令行工具(CLI) Vue.js 提供一個官方命令行工具,可用于快速搭建大型單頁應(yīng)用。該工具提供開...

    silencezwm 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<