Vue学习笔记-初识Vue

### 什么是 vue

1. 构建用户界面
   + 用 vue 往 html 页面中填充数据,非常的方便
2. 框架
   + 框架是一套现成的解决方案,程序员只能遵守框架的规范,去编写自己的业务功能!
   + 要学习 vue,就是在学习 vue 框架中规定的用法!
   + vue 的指令、组件(是对UI结构的复用)、路由、Vuex、vue 组件库
   + 只有把上面老师罗列的内容掌握以后,才有开发 vue 项目的能力!

### vue 的两个特性

1. 数据驱动视图:

   + 数据的变化会**驱动视图**自动更新
   + 好处:程序员只管把数据维护好,那么页面结构会被 vue 自动渲染出来!

2. 双向数据绑定:

   > 在网页中,form 表单负责**采集数据**,Ajax 负责**提交数据**。

   + js数据的变化,会被自动的渲染到页面上
   + 页面上表单采集的数据发生变化的时候,会被vue自动获取到,并更新到js数据中

> 注意:数据驱动视图和双向数据绑定的底层原理是 MVVM(Model数据源、view视图,ViewModel就是vue的实例)

### vue 指令

#### 1. 内容渲染指令

1. `v-text` 指令的缺点:会覆盖原有的内容!!
2. `{{ }}` 插值表达式:在实际开发中用的最多,只是内容的占位符,不会覆盖原有的内容!
3. `v-html` 指令的作用:可以把带有标签的字符串,渲染成真正的 HTML 内容!

#### 2. 属性绑定指令

>  注意:插值表达式只能用在元素的**内容节点**中,不能用在元素的**属性节点**中!

+ 在 vue 中,可以使用 `v-bind:` 指令,为元素的属性动态绑定值;

+ 简写是英文的":"

+ 在使用 v-bind 属性绑定期间,如果绑定内容需要进行动态拼接,则字符串的外面应该包裹单引号,例如:

  ```xml
  <div :title="'box' + index">这是一个 div</div>
  ```

#### 3. 事件绑定

1. `v-on:` 简写是 `@`

2. 语法格式为:

   ```xml
   <button @click="add"></button>
   
   methods: {
      add() {
               // 如果在方法中要修改 data 中的数据,可以通过 this 访问到
               this.count += 1
      }
   }
   ```
   **在使用 v-on 指令绑定事件时,可以使用 ( ) 进行传参**

3. `$event` 的应用场景:如果默认的事件对象 e 被覆盖了,则可以手动传递一个 $event。例如:

   ```xml
   <button @click="add(3, $event)"></button>
   
   methods: {
      add(n, e) {
               // 如果在方法中要修改 data 中的数据,可以通过 this 访问到
               this.count += 1
      }
   }
   ```

4. 事件修饰符:

   + `.prevent`

     ```xml
     <a @click.prevent="xxx">链接</a>
     ```

   + `.stop`

     ```xml
     <button @click.stop="xxx">按钮</button>
     ```

     

#### 4. v-model 指令

1. input 输入框
   + type="radio"
   + type="checkbox"
   + type="xxxx"
2. textarea
3. select

#### 5. 条件渲染指令

1. `v-show` 的原理是:动态为元素添加或移除 **display:none** 样式,来实现元素的显示和隐藏
   + 如果要频繁的切换元素的显示状态,用 v-show 性能会更好
2. `v-if` 的原理是:每次动态创建或移除元素,实现元素的显示和隐藏
   + 如果刚进入页面的时候,某些元素默认不需要被展示,而且后期这个元素很可能也不需要被展示出来,此时 v-if 性能更好

>  在实际开发中,绝大多数情况,不用考虑性能问题,直接使用 v-if 就好了!!!

v-if 指令在使用的时候,有两种方式:

1. 直接给定一个布尔值 true 或 false

   ```xml
   <p v-if="true">被 v-if 控制的元素</p>
   ```

2. 给 v-if 提供一个判断条件,根据判断的结果是 true 或 false,来控制元素的显示和隐藏

   ```xml
   <p v-if="type === 'A'">良好</p>
   ```
   
 #### 6.列表渲染指令  
 
 vue 提供了 v-for 列表渲染指令,用来辅助开发者基于一个数组来循环渲染一个列表结构。v-for 指令需要使
用 item in items 形式的特殊语法,其中:
items 是待循环的数组
 item 是被循环的每一项
    <!-- 官方建议:只要用到了 v-for 指令,那么一定要绑定一个 :key 属性 -->
        <!-- 而且,尽量把 id 作为 key 的值 -->
        <!-- 官方对 key 的值类型,是有要求的:字符串或数字类型 -->
        <!-- key 的值是千万不能重复的,否则会终端报错:Duplicate keys detected -->

   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值