首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Vue(上)

    ,所以读取的也是字符串,需要使用JSON.parse方法转为对象 console.log(JSON.parse(result)) // 读取不存在的数据将返回null...,所以读取的也是字符串,需要使用JSON.parse方法转为对象 console.log(JSON.parse(result)) // 读取不存在的数据将返回null...,oldValue) } }) vm使用时机:在创建实例时无法明确要监视的属性,后续实例创建完成后才进行属性监视,此时就需要使用调用vm进行监视...}, // 此时直接监视userInfo将不会生效,因为watch默认是无法监视data中的多层次属性的改变的,即watch默认监视的是key(userInfo)中的value...它必须用于向响应式对象上添加新 property,因为 Vue 无法探测普通的新增 property (比如 this.myObject.newProperty = 'hi') 注意对象不能是 Vue

    2.5K20

    【编程鹿】学Vue.js这一篇就够了「万字学会|通俗易懂」上篇

    在这个div范围以外的部分是无法使用vue特性的。...数据 当Vue实例被创建时,它会尝试获取在data中定义的所有属性,用于视图的渲染,并且监视data中的属性变化,当data发生改变,所有相关的视图都将重新渲染,这就是“响应式“系统。...示例: v-for="(item,index) in items" :key="index"> 这里使用了一个特殊语法::key="" 后面会讲到,它可以让你读取...通俗的来说:过滤器是对即将显示的数据做进一步的筛选处理,然后进行显示,值得注意的是过滤器并没有改变原来的数据,只是在原数据的基础上产生新的数据。...,否则就无法复用了,因此没有el属性。

    12.4K20

    【揭秘Vue核心】为什么不建议在 v-for 指令中使用 index 作为 key,让你秒懂!

    问题:为什么不建议在 v-for 指令中使用 index 作为 key? v-for="(item, index) in items" :key="index"> 的顺序改变时,Vue 不会随之移动 DOM 元素的顺序,而是就地更新每个元素,确保它们在原本指定的索引位置上渲染。...而上面提到的比较新旧节点(diff 算法),就是在发生更新过程中,如何对新旧两份虚拟DOM进行比较的过程,遍历它们,找出它们之间的区别,并应用这其中的变化到真实的 DOM 上。...diff 算法 篇幅有限,无法详尽的说明 diff 的具体机制,只针对自己的理解,做简单梳理,目的是为了说明开头抛出的「为什么不建议在 v-for 指令中使用 index 作为 key」。...原因是虚拟DOM在比较元素的时候,因为DOM上的key等属性均未发生变化,所以其自身和内部的input均被复用了。 所以,在实际开发过程中不要把 index 作为 key 值。

    28820

    9个Vue开发技巧助力成为更好的工程师

    $route.params.id } } } 在组件中使用 $route 会使之与其对应路由形成高度耦合,从而使组件只能在某些特定的 URL 上使用,限制了其灵活性。...这里 props 是一个包含所有绑定属性的对象。...样式穿透 在开发中修改第三方组件样式是很常见,但由于 scoped 属性的样式隔离,可能需要去除 scoped 或是另起一个 style 。...,对象内部的属性被改变时无法触发 watch ,我们可以为其设置深度监听 export default { data: { studen: { name:...默认情况下,一个组件上的 v-model 会把 value 用作 prop 且把 input 用作 event,但是一些输入类型比如单选框和复选框按钮可能想使用 value prop 来达到不同的目的。

    4.2K20

    10 个 Vue 开发技巧,助力成为更好的工程师!

    $route.params.id } } } 在组件中使用 $route 会使之与其对应路由形成高度耦合,从而使组件只能在某些特定的 URL 上使用,限制了其灵活性。...这里 props 是一个包含所有绑定属性的对象。.../v2/guide/render-function.html#函数式组件 样式穿透 在开发中修改第三方组件样式是很常见,但由于 scoped 属性的样式隔离,可能需要去除 scoped 或是另起一个 style...,对象内部的属性被改变时无法触发 watch ,我们可以为其设置深度监听 export default { data: { studen: { name:...文档:https://cn.vuejs.org/v2/guide/components-edge-cases.html#程序化的事件侦听器 手动挂载组件 在一些需求中,手动挂载组件能够让我们实现起来更加优雅

    1.8K10

    看,官方出品了 Vue 编码风格指南

    https://github.com/vuejs/cn.vuejs.org/blob/master/src/v2/style-guide/index.md 前言 这里是官方的 Vue 特有代码的风格指南...== -1 } } } 避免 v-if 和 v-for 用在一起 必要 一般我们在两种常见的情况下会倾向于这样做: 为了过滤一个列表中的项目 (比如 v-for="user in...通过将其更换为在如下的一个计算属性上遍历: computed: { activeUsers: function () { return this.users.filter(function...在 JavaScript 中,用多行分隔对象的多个属性是很常见的最佳实践,因为这样更易读。模板和 JSX 值得我们做相同的考虑。...易于阅读 简化计算属性要求你为每一个值都起一个描述性的名称,即便它不可复用。这使得其他开发者 (以及未来的你) 更容易专注在他们关心的代码上并搞清楚发生了什么。

    1.3K10

    看,官方出品了 Vue 编码风格指南!

    https://github.com/vuejs/cn.vuejs.org/blob/master/src/v2/style-guide/index.md 前言 这里是官方的 Vue 特有代码的风格指南...== -1 } } } 避免 v-if 和 v-for 用在一起 必要 一般我们在两种常见的情况下会倾向于这样做: 为了过滤一个列表中的项目 (比如 v-for="user in...通过将其更换为在如下的一个计算属性上遍历: computed: { activeUsers: function () { return this.users.filter(function...在 JavaScript 中,用多行分隔对象的多个属性是很常见的最佳实践,因为这样更易读。模板和 JSX 值得我们做相同的考虑。...易于阅读 简化计算属性要求你为每一个值都起一个描述性的名称,即便它不可复用。这使得其他开发者 (以及未来的你) 更容易专注在他们关心的代码上并搞清楚发生了什么。

    1.4K10

    1. VUE完整系统简介

    该属性决定了这个vue对象挂载到那个元素上, 可以看出, 我们这里是挂载到了id="app"的元素上 data: 这个属性用来存储数据, 这些数据可以试试手动写的, 也可以是动态从服务端取的 data...对象 这里指定了当前构建的vue对象挂载在id="app"的元素上....在vue里面,要想增加一个事件, 那就放在methods属性里就可以了. 这里有一点需要注意....Vuejs的MVVM   1. 什么是MVVM     MVVM是Model-View-ViewModel的简写。它本质上就是MVC 的改进版。...视图       就像在MVC和MVP模式中一样,视图是用户在屏幕上看到的结构、布局和外观(UI)。 视图模型       视图模型是暴露公共属性和命令的视图的抽象。

    2K10

    Vue中keep-alive组件的理解

    ,也就意味着不会重走生命周期函数,保持了当前的组件的状态,在第一次创建的时候回正常触发其创建生命周期,但是由于组件其实并未销毁,所以不会触发组件的销毁生命周期,而当组件在<keep-alive...}, deactivated: function(){ console.log("deactivated"); }, } 可以接收3个属性做为参数进行匹配对应的组件进行缓存...,通常还可以配合vue-router在定义时的meta属性以及在template定义的进行组件的有条件的缓存控制。...,如果在其中有v-for则不会工作,如果有上述的多个条件性的子元素,要求同时只有一个子元素被渲染,通俗点说,最多同时只能存在一个子组件,在<keep-alive...$destroy() } cache[key] = null remove(keys, key) } 在每次渲染即render时,首先获取第一个子组件,之后便是获取子组件的配置信息

    1K10

    Vue初步认识与Vue基础指令

    单向数据绑定 对于输入框等可输入元素,可设置双向数据绑定 双向数据绑定是在数据绑定基础上,可自动将元素输入内容更新给数据, 实现数据与元素内容的双向绑定。...特点: data中的数据是直接可以在视图中通过插值表达式访问 data的数据为响应式数据,发生改变时,视图会自动更新 特殊情况: data中存在数组时,索引操作和length操作无法自动更新视图...运行结果 v-for注意点 使用 v-for 的同时,应始终指定唯一的 key 属性,可以提高渲染性能并避免问题。...不是真正意义上的元素) v-show的本质就是元素内部的display属性是否为true v-if指令 用于根据条件,控制元素的创建与移除 <div id="app"...应用于同一个标签 更好的解决办法:将v-if和v-for分开,比如将v-if放在父元素上 <li

    3.1K30

    前端:Vue前端开发规范,值得收藏!

    为v-for设置键值 总是用 key 配合 v-for。 在组件上_总是_必须用 key 配合 v-for,以便维护内部组件及其子树的状态。...甚至在元素上维护可预测的行为,比如动画中的对象固化 (object constancy),也是一种好的做法。...一般我们在两种常见的情况下会倾向于这样做: 为了过滤一个列表中的项目 (比如 v-for="user in users" v-if="user.isActive")。...这些组件永远不接受任何 prop,因为它们是为你的应用定制的,而不是它们在你的应用中的上下文。如果你发现有必要添加 prop,那就表明这实际上是一个可复用的组件,只是目前在每个页面里只使用一次。...紧密耦合的组件名 和父组件紧密耦合的子组件应该以父组件名作为前缀命名。 如果一个组件只在某个父组件的场景下有意义,这层关系应该体现在其名字上。

    1.5K40
    领券