Vue

1.MVVM框架

1.M:模型層(Model)睡腿,主要負責業(yè)務數據相關;
2.V:視圖層(View)爷光,顧名思義垫竞,負責視圖相關,細分下來就是html+css層蛀序;
3.VM:(ViewModel)V與M溝通的橋梁欢瞪,也可以看作為控制器,負責監(jiān)聽M或者V的修改徐裸,是實現MVVM雙向綁定的要點遣鼓;

MVVM支持雙向綁定,意思就是當M層數據進行修改時重贺,VM層會監(jiān)測到變化譬正,并且通知V層進行相應的修改,反之修改V層則會通知M層數據進行修改檬姥,以此也實現了視圖與模型層的相互解耦;


2.初識Vue

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <body>
        <div id="d1">
            <p>{{mytxt}}</p>
        </div>
        <script>
            let vm=new Vue({
                el:'#d1',
                data:{
                    mytxt:'歡迎使用Vue.js'
                }
            })
        </script>
    </body>
</html>

3.Vue數據的綁定

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <!-- 引入vue -->
        <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
        <title></title>
    </head>
    <body>
        <div id="d2">
            <!-- 雙向綁定 -->
            <input type="text" name="" id="" v-model="pname" />
            <br>
            <p>產品名稱:{{pname}}</p>
            <!-- 單項綁定-->
            <input type="text" name="" id="" v-bind:value="price" />
            <br>
            <p>產品價格:{{price}}</p>
        </div>
        <script type="text/javascript">
            let sm=new Vue({
                el:'#d2',
                data:{
                    pname:'計算機',
                    price:1000
                }
            })
        </script>
    </body>
</html>

4.屬行的綁定

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
        <title></title>
        <style type="text/css">
            .one{
                color: yellow;
            }
            .two{
                color: red;
            }
        </style>
    </head>
    <body>
        <div id="d">
            <p v-bind:class="bg">李濟啊</p>
            <input type="button" name="" id="" value="點擊換顏色" v-on:click="ccc" />
            <ul v-for="k in arr">
                <li>{{k}}</li>
            </ul>
            <input type="button" name="" id="" value="加++" v-on:click="addarr" />
        </div>
        <script type="text/javascript">
            let z=new Vue({
                el:'#d',
                data:{
                    bg:'one',
                    arr:[1,2,3]
                },
                methods:{
                    ccc(){
                        if(this.bg=='one'){
                            this.bg='two'
                        }else{
                            this.bg='one'
                        }
                    },
                    addarr(){
/*                      后臺增加,頁面不變
                        for(let k in this.arr){
                            this.arr[k]+=2
                        }
                        console.log(this.arr) */
                        //變異方法改變數組在頁面的呈現
                        for(let k in this.arr){
                            this.arr.splice(k,1,this.arr[k]+=1)
                        }
                        
                    }
                }
            })
        </script>
    </body>
</html>

5.函數

<!DOCTYPE html>
<html>
   <head>
       <meta charset="utf-8">
       <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
       <title></title>
   </head>
   <body>
       <div id="d">
           <input type="button" name="" id="" value="點擊" v-on:click="show" />
           <input type="button" name="" id="" value="點擊" v-on:click="display" />
           <input type="button" name="" id="" value="增加" v-on:click="add"/>
           <p>運算結果{{num}}</p>
       </div>
       <script type="text/javascript">
           let z=new Vue({
               el:'#d',
               data:{
                   num:1
               },
               methods:{
                   //以匿名函數的形式聲明
                   show:function(){
                       alert('歡迎使用Vue中的函數')
                   },
                   //非匿名函數不加function
                   display(){
                       alert('另一種形式的Vue函數聲明')
                   },
                   add(){
                       this.num+=1;
                   }
               }
           })
       </script>
   </body>
</html>

6.函數之頁面切換案例

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
        <style type="text/css">
            div{
                width: 200px;
                height: 200px;
                border: 1px solid blue;
            }
            .show{
                display: block;
            }
            .hide{
                display: none;
            }
            li{
                display: inline-block;
                border: 1px solid red;
            }
            #d1{
                background-color: yellow;
            }
            #d2{
                background-color: pink;
            }
            #d3{
                background-color: aqua;
            }
        </style>
    </head>
    <body>
        <div id="con">
        
            <ul>
                <li id="m1" v-on:click="xianshi2()">菜單1</li>
                <li id="m2" v-on:click="xianshi2()">菜單2</li>
                <li id="m3" v-on:click="xianshi2()">菜單3</li>
            </ul>
            <div v-show="num==0" id="d1">
                功能區(qū)1
            </div>
            <div v-show="num==1" id="d2">
                功能區(qū)2
            </div>
            <div v-show="num==2" id="d3">
                功能區(qū)3
            </div>
        </div>
        <script type="text/javascript">
            let vm=new Vue({
                el:'#con',
                data:{
                    num:0
                },
                methods:{
                    xianshi2(){
                        //獲取當前被點擊的li
                        let cur=event.srcElement;
                        //得到li所在的ul
                        let ul=cur.parentElement;
                        //獲取所有l(wèi)i的集合
                        let lis=ul.children;
                        for(var i in lis){
                            if(lis[i]==cur){
                                this.num=i;
                                break;
                            }
                        }
                        console.log(this.num)
                    }
                }
            })          
            
        </script>
    </body>
</html>

7.監(jiān)聽器

<!DOCTYPE html>
<html>
  <head>
      <meta charset="utf-8">
      <title></title>
      <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
  </head>
  <body>
      <div id="port">
          <input type="button" name="" id="" value="改變" v-on:click="change()" />
      </div>
      <script type="text/javascript">
          let vm=new Vue({
              el:'#port',
              data:{
                  num:10
              },
              methods:{
                  change(){
                      this.num+=3;
                  }
              },
              //淺度監(jiān)聽器
              watch:{
                  //函數名跟定義變量名一樣
                  num(newvalue,oldvalue){
                      console.log("原有數值"+oldvalue+"新數值"+newvalue);
                  }
              }
          })
      </script>
  </body>
</html>

8.過濾器

<!DOCTYPE html>
<html>
   <head>
       <meta charset="utf-8">
       <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
       <title></title>
   </head>
   <body>
       <div id="h">
           <p>{{num|fail}}</p>
       </div>
       <script type="text/javascript">
           Vue.filter('fail',function(value){
               let date=new Date
               let mouth=date.getMonth()+1
                   return 'CNN'+value+"EP"+date.getFullYear()+mouth+date.getDate()+date.getHours()+date.getMinutes()+date.getSeconds()
           })
               
           
           Vue.filter('star',function(value){
               return "CNN"+value
           })
           let z=new Vue({
               filters:{
                   tail(value){
                       return value+"EP"
                   }
               },
               el:'#h',
               data:{
                   num:210423
               }
           })
       </script>
   </body>
</html>

9.猜數字案例

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
        <title>猜數字</title>
        <!--樣式代碼放置于style標簽里-->
        <style>
            /*
             形式1:
             #標簽ID名{
                標簽屬性名(例如邊框粉怕、背景等):屬性值1 屬性值2 屬性值3... ;
                標簽屬性名(例如邊框健民、背景等):屬性值1 屬性值2 屬性值3... ;
                標簽屬性名(例如邊框、背景等):屬性值1 屬性值2 屬性值3... ;
                ....
             }
             形式2:
            標簽名稱{
                標簽屬性名(例如邊框贫贝、背景等):屬性值1 屬性值2 屬性值3... ;
                標簽屬性名(例如邊框秉犹、背景等):屬性值1 屬性值2 屬性值3... ;
                標簽屬性名(例如邊框蛉谜、背景等):屬性值1 屬性值2 屬性值3... ;
                ....
            }
            還有其他形式    
             * */
            #main{
                 /*border: 1px solid black;*/
                 background-image: url(img/main.png);
                 background-size:cover;
                 height: 477px;
                 width:555px;
                 position: fixed;
                 top:51px;
                 left:498px;
            }
            #txt{
                /*border: 2px solid blue;*/
                width:360px;
                height: 62px;
                position: fixed;
                left:624px;
                top:300px;
            }
            #im{
                /*border: 2px solid red;*/
                height: 120px;
                width:110px;
                position: fixed;
                left:750px;
                top:370px;
            }
            #result{
                /*border: 2px solid green;*/
                height: 193px;
                width: 177px;
                position: fixed;
                left:1095px;
                top:214px;
            }
            input{
                width:360px;
                height:45px;
                text-align: center;
                border: none;
                outline: none;
                font-size: 20px;
            }
            #button{
                height: 120px;
                width:110px;
            }
            #big{
                height: 193px;
                width: 177px;
            }
            body{
                background-image: url(img/bg.jpg);
                background-size: cover;
                background-repeat: no-repeat;
                height: 100%;
            }
            html{
                height: 100%;
            }
        </style>

    </head>
    <body>
        <div id="app">
            <div id="main">
                <div id="txt">
                    <input type="text" id="info" v-model="num" />
                </div>
                <div id="im">
                    <img id="button" src="img/button.png" v-on:click="com" />
                </div>
            </div>
            <div id="result">
                <img id="big" v-bind:src="imgsrc" />
            </div>
        </div>
        <script type="text/javascript">
            //當頁面載入就生成一個隨機數
            var num = 31 * Math.random();
            //對隨機數取整
            var num2 = Math.round(num);

            let z = new Vue({
                el: '#app',
                data: {
                    num: '',
                    imgsrc: 'img/noPic.png'
                    },
                methods: {
                    com() {
                        let iv = this.num;
                        if (iv.length == 0) {
                            alert('請輸入數字,文本框里不能為空白');
                        } else if (isNaN(iv)) {
                            alert('你的不是數字崇堵,請重新輸入');
                        } else {
                        //以用戶輸入數值iv和隨機數num2進行比較
                        //如果用戶輸入的數值大于隨機數型诚,則顯示圖片big.png
                            if (iv > num2) {
                                this.imgsrc = "img/big.png";
                        //如果用戶輸入的數值小于隨機數,則顯示圖片small.png 
                            } else if (iv < num2) {
                                this.imgsrc = "img/small.png";
                        //如果用戶輸入的數值等于隨機數鸳劳,則顯示圖片win.png   
                            } else {
                                this.imgsrc = "img/win.png";
                            }
                        }
                   }
                }
            })
        </script>
    </body>
</html>

10.員工信息案例

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
    </head>
    <body>
        <div id="app">
            <table>
                <tr>
                    <th>人物編號</th>
                    <th>人物姓名</th>
                    <th>人物年齡</th>
                    <th>人物職位</th>
                </tr>
                <tr v-for="i in info">
                    <td>{{i.no}}</td>
                    <td>{{i.name}}</td>
                    <td>{{i.age}}</td>
                    <td>{{i.job}}</td>
                    <td><input type="button" name="" id="" value="刪除" v-on:click="del(index)" /></td>
                </tr>
            </table>
            <input type="text" name="" id="" value="" placeholder="名字" v-model="name" /><br>
            <input type="text" name="" id="" value="" placeholder="年齡" v-model="age" /><br>
            <input type="text" name="" id="" value="" placeholder="職位" v-model="job" /><br>
            <input type="button" name="" id="" value="添加員工" v-on:click="add()" />
        </div>
        <script type="text/javascript">
            let vm = new Vue({
                el: '#app',
                data: {
                    info: [{
                        no: 1,
                        name: '曹操',
                        age: '60',
                        job: '丞相'
                    }, {
                        no: 2,
                        name: '袁紹',
                        age: '50',
                        job: '將軍'
                    }],
                    name: '',
                    age: '',
                    job: ''
                },
                methods: {
                    add() {
                        let no = 0;
                        if (this.info.length == 0) {
                            no = 1;
                        } else {
                            no = this.info[this.info.length - 1].no + 1;
                        }
                        this.info.push({
                            no: no,
                            name: this.name,
                            age: this.age,
                            job: this.job
                        });
                    },
                    del(index) {
                        this.info.splice(index, 1);
                    }
                }

            });
        </script>
    </body>
</html>

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末狰贯,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子赏廓,更是在濱河造成了極大的恐慌涵紊,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件幔摸,死亡現場離奇詭異摸柄,居然都是意外死亡,警方通過查閱死者的電腦和手機既忆,發(fā)現死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門驱负,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人患雇,你說我怎么就攤上這事跃脊。” “怎么了庆亡?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵匾乓,是天一觀的道長。 經常有香客問我又谋,道長拼缝,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任彰亥,我火速辦了婚禮咧七,結果婚禮上,老公的妹妹穿的比我還像新娘任斋。我一直安慰自己继阻,他們只是感情好,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布废酷。 她就那樣靜靜地躺著瘟檩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪澈蟆。 梳的紋絲不亂的頭發(fā)上墨辛,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天,我揣著相機與錄音趴俘,去河邊找鬼睹簇。 笑死奏赘,一個胖子當著我的面吹牛,可吹牛的內容都是我干的太惠。 我是一名探鬼主播磨淌,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼凿渊!你這毒婦竟也來了梁只?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤嗽元,失蹤者是張志新(化名)和其女友劉穎敛纲,沒想到半個月后,有當地人在樹林里發(fā)現了一具尸體剂癌,經...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡淤翔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現自己被綠了佩谷。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片旁壮。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖谐檀,靈堂內的尸體忽然破棺而出抡谐,到底是詐尸還是另有隱情,我是刑警寧澤桐猬,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布麦撵,位于F島的核電站,受9級特大地震影響溃肪,放射性物質發(fā)生泄漏免胃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一惫撰、第九天 我趴在偏房一處隱蔽的房頂上張望羔沙。 院中可真熱鬧,春花似錦厨钻、人聲如沸扼雏。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽诗充。三九已至,卻和暖如春诱建,著一層夾襖步出監(jiān)牢的瞬間其障,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工涂佃, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留励翼,地道東北人。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓辜荠,卻偏偏與公主長得像汽抚,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子伯病,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內容

  • 文章參考阮一峰:MVC造烁,MVP 和 MVVM 的圖示深入響應式原理 最近工作中一直在使用Vue這一款框架作為開發(fā)工...
    大春春閱讀 33,212評論 4 27
  • 一、概念介紹 Vue.js和React.js分別是目前國內和國外最火的前端框架午笛,框架跟類庫/插件不同惭蟋,框架是一套完...
    劉遠舟閱讀 1,043評論 0 0
  • react與vue的區(qū)別 vue使用的是template模版編寫。react使用的是jsx語法药磺。狀態(tài)管理:reac...
    小米和豆豆閱讀 291評論 0 0
  • ?1??告组、Vue和其他兩大框架的區(qū)別 Angular 學習成本太高 React 代碼可讀性差 Vue 學習成本較低...
    藍海00閱讀 74,007評論 40 1,231
  • MVVM model和view層通過中間的vm連接和驅動。model層數據變化會改變視圖癌佩,view改變通過事件來修...
    Super曲江龍Kimi閱讀 697評論 0 1