是的,这里有很全的vue指令使用~

1.简单的vue应用

vue作为一个mvvm框架,想想为什么叫做mvvm?

Model是负责数据的存储,

View负责页面的展示

Model View 

负责业务逻辑处理,对数据加工后视图展示

MVVM的作用是业务逻辑代码与视图代码完全分离,各自的职责更加清晰~

<body>
    <!--mvvm里面的v-->
    <div id="app">
        {{val}}
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script >
        //这是mvvm里面的vm
        var vm=new Vue({
            el:'#app',
           //这是mvvm里面的m 
            data:{
                val:'你好'
            }
        })
    </script>

</body

2.v-text

 <div id="app" v-text="val"> 
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script >
        //这是mvvm里面的vm
        var vm=new Vue({
            el:'#app',
           //这是mvvm里面的m 
            data:{
                val:'你好'
            }
        })
    </script>

视图:

 这里的v-text是偏向于文本的,如果你将 val:'你好'改成val:'<p style="color:red">你好</p>'

视图是

所以接下来就是介绍v-html

3.v-html

<body>
    <!--mvvm里面的v-->
    <div id="app" v-html="val"> 
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script >
        //这是mvvm里面的vm
        var vm=new Vue({
            el:'#app',
           //这是mvvm里面的m 
            data:{
                val:'<p style="color:red">你好</p>'
            }
        })
    </script>
</body>

视图:

v-text是把所有的都以文本的形式展现,而v-html能够解析里面的标签~

4 v-cloak

平常我们的数据都是用{{}}渲染出来的,那么这样的渲染与v-html和v-text有什么区别呢?

在网络不行的情况下,我们用{{}}的形式渲染会出现闪现{{}},再出现数据,所以将这个指令放在要渲染的标签的父元素上就可以,还要记得写样式display:none当然你可以放在刚开始vue定义的范围的标签上

 <style>
        [v-cloak]{
          display: none  
        }
    </style>
</head>
<body>
    <!--mvvm里面的v-->
    <div id="app" v-cloak>
        {{val}}
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script >
        //这是mvvm里面的vm
        var vm=new Vue({
            el:'#app',
           //这是mvvm里面的m 
            data:{
                val:'你好'
            }
        })
    </script>

</body>

5.v-for

 <div id="app">
        <div v-for="(el,index) in dataList">
            <p>名字:{{el.name}}</p>
            <p>年龄:{{el.age}}</p>
        </div>
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script>
        //这是mvvm里面的vm
        var vm = new Vue({
            el: '#app',
            //这是mvvm里面的m 
            data: {
                val: '你好',
                dataList:[
                    {
                        name:'jack',
                        age:18
                    },
                    {
                        name:'rose',
                        age:17
                    }
                ]
            }
        })
    </script>

这里要注意的是:

一般都加上:     

    <div v-for="(el,index) in dataList" :key="index" >
            <p>名字:{{el.name}}</p>
            <p>年龄:{{el.age}}</p>
        </div>         
:key="index"   或者如果el里面有id 的话可以写:key="el.id" 这样来区分每一个list,因为在渲染的时候都是整个list渲染的,加上这个就只用替换,或者说是局部的变化

6.v-on

 <div id="app">
         <button type="button" v-on:click="clickMe()">爱我你就点点我</button>
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script >
        //这是mvvm里面的vm
        var vm=new Vue({
            el:'#app',
           //这是mvvm里面的m 
            data:{
                val:'你好'
            },
            methods:{
                clickMe(){
                     alert(this.val)
                }

            }
        })
    </script>
v-on:click="clickMe()"  简写:click="clickMe()"就可以了
这里的this代表的就是vm啦,你直接用vm.val也是一样的
视图:

 

7.v-if
<body>
    <!--mvvm里面的v-->
    <div id="app">
        <p  v-if="val=='你好'">
            Good boy
        </p>
    </div>
    <script src="./node_modules/vue/dist/vue.js"></script>
    <script >
        //这是mvvm里面的vm
        var vm=new Vue({
            el:'#app',
           //这是mvvm里面的m 
            data:{
                val:'你好'
            }
        })
    </script>

</body>

 视图:

v-if和v-show的区别,v-show只是hidden,v-if是直接元素消失......

posted on 2018-04-29 20:36  周小姐你好  阅读(239)  评论(0编辑  收藏  举报