Vue基础学习——基础语法2

简介: Vue基础学习——基础语法2

一、v-show和 v-if的区别

首先我们要明确的是:


1.v-show是不支持template

2.v-show不可用和v-else一起使用;


其次两者本质的区别:


1.v-show元素无论是否需要显示。它的Dom实际上都存在

2.v-if当条件为false的时候;其对应的原生压根不会渲染到dom中


最后两者的使用场景:


1.如果我们的原生需要在显示和隐藏之间频繁的切换,那么使用v-show否则就使用v-if

二、v-for列表渲染

基本使用


基本格式是: item in arr


item是我们给每项元素起的一个别名, arr是数组名称


当我们遍历一个数组的时候有时候会需要拿到数组的索引


我们可以使用格式:(item, index) in arr;

<thead>
          <tr>
            <th style="width: 25%">名称</th>
            <th style="width: 20%">价格</th>
            <th style="width: 25%">数量</th>
            <th style="width: 30%">操作</th>
          </tr>
        </thead> 
<tbody>
          <tr v-for="(a, index) in shopArr" :key="a.name">
            <td>{{a.name}}</td>
            <td>{{a.price}}</td>
            <td>
              <button>-</button>
              <span>{{a.num}}</span>
              <button>+</button>
            </td>
            <td>
              <button>编辑</button>
              <button>删除</button>
            </td>
          </tr>
        </tbody>


注意


同时使用 v-if 和 v-for 是不推荐的,因为这样二者的优先级不明显。当它们同时存在于一个节点上时,v-if 比 v-for 的优先级更高。这意味着 v-if 的条件将无法访问到 v-for 作用域内定义的变量别名。

<!--
 这会抛出一个错误,因为属性 todo 此时
 没有在该实例上定义
-->
<li v-for="todo in todos" v-if="!todo.isComplete">
  {{ todo.name }}
</li>

三、v-model绑定表单数据

概念:


 1.v-model指令可以在表单 input,textarea以及select元素上创建双向数据绑定。


 2.他会根据控件类型自动选择正确的方法来更新元素。    


 3.v-model本质上是语法糖,它负责监听用户的输入事件来更新数据,并在极端场景下进行一些特殊处理;


原理:


1.v-bind绑定value属性的值;


2.v-on绑定input事件监听到函数中,函数会获取最新的值赋值到绑定的属性中


具体使用:


//绑定textarea article是一个字符串
<textarea v-model="article"> </textarea>
//绑定checkbox -单个勾选框 isAgree是一个布尔值
<input id='agreement' type="checkbox" v-model="isAgree" />
//绑定checkbox -多个复选框 hobbies是一个数组
<label for="basketball">
  <input id="basketball" type="checkbox" v-model="hobbies" value="basketball"> 篮球
</label>
<label for="football">
  <input id="football" type="checkbox" v-model="hobbies" value="football"> 足球
</label>
<label for="tennis">
  <input id="tennis" type="checkbox" v-model="hobbies" value="tennis"> 网球
</label>
//radio gender是一个字符串 是input的value
<label for="male">
  <input id="male" type="radio" v-model="gender" value="male">男
</label>
<label for="female">
  <input id="female" type="radio" v-model="gender" value="female">女
</label>
// 绑定select fruit是一个字符串的时候就是单选,如果是一个数组就是多选
<select v-model="fruit" multiple size="2">
  <option value="apple">苹果</option>
  <option value="orange">橘子</option>
  <option value="banana">香蕉</option>
</select>

关于v-model的修饰符:


1. -lazy


默认情况下,v-model在进行双向绑定时,绑定的是input事件那么每次输入后就会将最新的值和绑定的属性进行同步,如果我们加上lazy符号那么绑定的事件切换为change事件,只有在提交时候才会触发。


2. - number


如果我们希望将输入转化为数字,那么就使用.number在可以转化的情况下,会将其转化为number类型。


3. -trim


如果要自动过滤掉用户输入的空白字符,可以给v-model后面在上.trim修饰符。


相关文章
|
3月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
329 2
|
2月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
304 137
|
6月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
818 0
|
5月前
|
人工智能 JSON JavaScript
VTJ.PRO 首发 MasterGo 设计智能识别引擎,秒级生成 Vue 代码
VTJ.PRO发布「AI MasterGo设计稿识别引擎」,成为全球首个支持解析MasterGo原生JSON文件并自动生成Vue组件的AI工具。通过双引擎架构,实现设计到代码全流程自动化,效率提升300%,助力企业降本增效,引领“设计即生产”新时代。
437 1
|
5月前
|
JavaScript 安全
在 Vue 中,如何在回调函数中正确使用 this?
在 Vue 中,如何在回调函数中正确使用 this?
275 0
|
8月前
|
JavaScript
vue实现任务周期cron表达式选择组件
vue实现任务周期cron表达式选择组件
1053 4
|
6月前
|
JavaScript UED
用组件懒加载优化Vue应用性能
用组件懒加载优化Vue应用性能
|
7月前
|
JavaScript 数据可视化 前端开发
基于 Vue 与 D3 的可拖拽拓扑图技术方案及应用案例解析
本文介绍了基于Vue和D3实现可拖拽拓扑图的技术方案与应用实例。通过Vue构建用户界面和交互逻辑,结合D3强大的数据可视化能力,实现了力导向布局、节点拖拽、交互事件等功能。文章详细讲解了数据模型设计、拖拽功能实现、组件封装及高级扩展(如节点类型定制、连接样式优化等),并提供了性能优化方案以应对大数据量场景。最终,展示了基础网络拓扑、实时更新拓扑等应用实例,为开发者提供了一套完整的实现思路和实践经验。
891 77
|
8月前
|
缓存 JavaScript 前端开发
Vue 基础语法介绍
Vue 基础语法介绍
|
6月前
|
JavaScript 前端开发 开发者
Vue 自定义进度条组件封装及使用方法详解
这是一篇关于自定义进度条组件的使用指南和开发文档。文章详细介绍了如何在Vue项目中引入、注册并使用该组件,包括基础与高级示例。组件支持分段配置(如颜色、文本)、动画效果及超出进度提示等功能。同时提供了完整的代码实现,支持全局注册,并提出了优化建议,如主题支持、响应式设计等,帮助开发者更灵活地集成和定制进度条组件。资源链接已提供,适合前端开发者参考学习。
483 17