vue基础知识

vue基础语法

介绍:Vue是一套用于构建用户界面的渐进式框架
Vue核心库只关注视图层,不仅容易上手,还便于与第三方既有项目整合
vue官网

Hello World

1.引入vue.js
2.创建一个带有id的dom
3.编写vue实例,el挂载点对应HTMLdom,data表示vue实例中的数据

 1 <div id="app">
 2     {{hello}}
 3 </div>
 4 <!-- 开发环境版本,包含了有帮助的命令行警告 -->
 5 <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
 6 <script>
 7     var app= new Vue({
 8         el:"#app",
 9         data:{
10             hello:"Hello world"
11         }
12     })
13 </script>

指令

1. v-text
更新元素的 textContent(标签内文字)。

v-text=””可以与{{}}替换使用

1、v-text没有vue因网速过慢导致加载的问题

2、{{}}前后可以加值,而v-text会覆盖元素中原来的内容

3、{{}}和v-text不能识别html语言,需要使用html

代码

 1     <body>
 2     <div id="app">
 3         <h2 v-text="msg"></h2>
 4         <p >{{msg}}</p>
 5      
 6     </div>
 7     <script>
 8        var vm =  new Vue({
 9            el: '#app',
10            data:{
11                msg:'养老院智能服务系统'
12            }
13        })
14     </script>
15     </body>
2.v-html

更新元素的 innerHTML (html标签会被编译)

代码展示

 1 <body>
 2 <div id="app">
 3     <h2 v-html="msg"></h2>
 4     <p >{{msg}}</p>
 5  
 6 </div>
 7 <script>
 8    var vm =  new Vue({
 9        el: '#app',
10        data:{
11            msg:'<h2 style="color: maroon">养老院智能服务系统</h2>'
12        }
13    })
14 </script>
15 </body>
3.v-show

根据表达式bool值,切换元素的 display 属性。

 1 <div id="app">
 2     <div v-show="ok" v-html="hello"></div>
 3     <div v-show="no" v-html="hello"></div>
 4 </div>
 5 <script>
 6     var app = new Vue({
 7         el:"#app",
 8         data:{
 9             ok:true,
10             no:false,
11             hello:"<h1>Hello Vue</h1>"
12         }
13     })
14 </script>

4.v-if、v-else、v-else-if

多个元素 通过条件判断展示或者隐藏某个元素

 1 <div id="app">
 2     <input v-model="score">
 3     <div v-if="score>=90">优秀</div>
 4     <div v-else-if="score>=80&&score<90">良好</div>
 5     <div v-else-if="score>=70&&score<80">一般</div>
 6     <div v-else>较差</div>
 7 </div>
 8 <script>
 9     var app = new Vue({
10         el:"#app",
11         data:{
12             score:100,
13         }
14     })
15 </script>

v-show 和 v-if的区别

  • v-show本质就是标签display设置为none,控制隐藏(适用于频繁切换显示)
  • v-if是动态的向DOM树内添加或者删除DOM元素

v-for

v-for 指令基于一个数组来渲染一个列表。v-for 指令需要使用 item in items 形式的特殊语法,其中 items 是源数据数组,而 item 则是被迭代的数组元素的别名。

 1 <div id="app">
 2     <ul>
 3         // item为当前遍历元素 index为下标 
 4         <li v-for="item in fruits">{{item}}</li>
 5         <li v-for="(item,index) in fruits">{{index}}-----{{item}}</li>
 6         <li v-for="item in myFruits">{{item.cname}}----{{item.ename}}</li>
 7         <li v-for="(item,index) in fruits" :key="index">{{item}}</li>
 8     </ul>
 9 </div>
10 <script>
11     var vue = new Vue({
12         el:"#app",
13         data:{
14             fruits:['apple','orange','aaa'],
15             myFruits:[{
16                 cname:"苹果",
17                 ename:"apple"
18             },{
19                 cname:"橙子",
20                 ename:"orange"
21             },{
22                 cname:"AAA",
23                 ename:"aaa"
24             }]
25         }
26     })
27 </script>

key 的作用:使得vue提高性能

v-for与v-if一同使用

不推荐在同一元素上使用 v-ifv-for

当它们处于同一节点,v-for 的优先级比 v-if 更高,这意味着 v-if 将分别重复运行于每个 v-for 循环中。性能不好

如果你的目的是有条件地跳过循环的执行,那么可以将 v-if 置于外层元素
<ul v-if="todos.length"> <li v-for="todo in todos"> {{ todo }} </li> </ul> <p v-else>No todos left!</p>

5.v-on:绑定事件

常用事件:click/mouseover/mouseup/

 1 <body>
 2 <div id="app">
 3     <h2 v-html="msg"></h2>
 4     <input type="button" value="点击报名" id="submit" v-on:click="result">
 5  
 6 </div>
 7 <script>
 8    var vm =  new Vue({
 9        el: '#app',
10        data:{
11            msg:'<h2 style="color: maroon">养老院智能服务系统</h2>'
12        },
13        methods:{
14            result:function(){
15                alert('报名成功')
16            }
17        }
18  
19    })
20 </script>
21 </body>

6.v-model 双向数据绑定

当文本输入框的内容发生变化时 会同步修改绑定的数据

如果直接修改data里面的值 也会同步修改文本输入框里面的文本

注意:只有指定的表单元素可以使用(input select textarea)

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4   <meta charset="UTF-8">
 5   <title>Title</title>
 6 </head>
 7 <body>
 8 
 9 <div id="app">
10   <!--<input type="text" v-model="message">-->
11   <!--<input type="text" :value="message" @input="valueChange">-->
12   <input type="text" :value="message" @input="message = $event.target.value">
13   <h2>{{message}}</h2>
14 
15   <!-- 简单双向绑定 -->
16   <input type="text" v-model = 'm'>{{m}}
17 </div>
18 
19 <script src="../js/vue.js"></script>
20 <!-- v-model 实现表单和数据的双向绑定 -->
21 <script>
22   const app = new Vue({
23     el: '#app',
24     data: {
25       message: '你好啊'
26     },
27     methods: {
28       valueChange(event) {
29         this.message = event.target.value;
30       }
31     }
32   })
33 </script>
34 <!-- <script>
35   // 双向绑定
36 const app = new Vue({
37   el: '#app',
38   data : {
39     m: 'hi'
40   }
41 });
42 </script> -->
43 </body>
44 </html>

修饰符

  <--.trim:去掉开始和结尾的空格 -->

 <input type="text" v-model.trim="num2">
posted @ 2020-12-19 10:15  花开荼蘼Ⅴ彼岸未归  阅读(157)  评论(0编辑  收藏  举报