Vue中一些重要的知识点

本文主要和大家分享vue中一些重要的知识点,希望能帮助到大家。

不要在选项属性或回调上使用箭头函数

比如

created: () => console.log(this.a)

vm.$watch(‘a’, newValue => this.myMethod())
因为箭头函数是和父级上下文绑定在一起的,this 不会是如你所预期的 Vue 实例,经常导致 Uncaught TypeError: Cannot read property of undefined 或 Uncaught TypeError: this.myMethod is not a function 之类的错误

立即学习“前端免费学习笔记(深入)”;

具体见:这里

v-html

双大括号会将数据解释为普通文本,而非 HTML 代码。为了输出真正的 HTML,你需要使用 v-html 指令:

Using mustaches: {{ rawHtml }}

Using v-html directive:

登录后复制

具体见:这里

计算属性缓存 vs 方法

我们可以将同一函数定义为一个方法而不是一个计算属性。两种方式的最终结果确实是完全相同的。然而,不同的是计算属性是基于它们的依赖进行缓存的。计算属性只有在它的相关依赖发生改变时才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。
这个 计算属性是基于它们的依赖进行缓存的 是什么意思呢?

computed: {  now: function () {    return Date.now()  }}

登录后复制

这里虽然Date.now()的值一直在变,但是他没有被watch,因为他不是响应式依赖。

具体见:这里

CSS样式自动添加前缀

当 v-bind:style 使用需要添加浏览器引擎前缀的 CSS 属性时,如 transform,Vue.js 会自动侦测并添加相应的前缀。

具体见: 这里

在 元素上使用 v-if 条件渲染分组

因为 v-if 是一个指令,所以必须将它添加到一个元素上。但是如果想切换多个元素呢?此时可以把一个  元素当做不可见的包裹元素,并在上面使用 v-if。最终的渲染结果将不包含 元素。

  

Title

Paragraph 1

Paragraph 2

登录后复制

具体见:这里

v-if 和 v-show 和 v-for

v-if 是对页面元素的添加和移除操作

v-show 是对页面元素的显示和隐藏操作

当 v-if 与 v-for 一起使用时,v-for 具有比 v-if 更高的优先级。

具体见:这里

数组更改检测注意事项

Vue 不能检测一下方式变动的数组,从而将不会触发视图更新

当你利用索引直接设置一个项时,例如:vm.items[indexOfItem] = newValue

当你修改数组的长度时,例如:vm.items.length = newLength

具体见:这里

对象更改检测注意事项

Vue 不能检测对象属性的添加或删除

var vm = new Vue({  data: {    a: 1  }})// `vm.a` 现在是响应式的vm.b = 2// `vm.b` 不是响应式的

登录后复制

但是我们可以通过 Vue.set(object, key, value)方法向嵌套对象添加响应式属性。
另外还有这个常用的方法 Object.assign(),当我们想要为某个对象赋予 多个新属性 的时候,你应该这么玩

this.userProfile = Object.assign({}, this.userProfile, {  age: 27,  favoriteColor: 'Vue Green'})

登录后复制

具体见: 这里

在 v-for 中使用 methods 方法

  • {{ n }}
  • 登录后复制

    具体见: 这里

    组件使用 v-for

    在自定义组件里,你可以像任何普通元素一样用 v-for。

    
    

    登录后复制

    具体见: 这里

    .once 事件修饰符(2.1.4 新增)

    登录后复制

    .once 也可以使用在 自定义组件 上。

    具体见:这里

    is 特性

    由于dom某些元素本身的一些限制,

    、、、 这样的元素里允许包含的元素有限制。

    Vue.component('txt',{ template: '
    I like money!
    '})new Vue({ el:'#app'})

    登录后复制

    将会解析成下面的dom

    I like money!

    登录后复制

    如果想要解析正确,需要使用 is 这个属性。

    登录后复制

    这样dom就解析正确了。

    I like money!

    登录后复制

    具体见:这里

    将对象的所有属性作为 prop 进行传递

    如果你想把一个对象的所有属性作为 prop 进行传递,可以使用不带任何参数的 v-bind (即用 v-bind 而不是 v-bind:prop-name)。例如,已知一个 todo 对象:

    todo: {  text: 'Learn Vue',  isComplete: false}

    登录后复制

    然后:

    
    

    登录后复制

    将等价于:

    
    

    登录后复制

    具体见: 这里

    非 Prop 特性的替换与合并

    class 和 style这两个特性的值都会做合并 (merge) 操作

    其他属性(如: type) 则会进行覆盖

    具体见: 这里

    Props的一般绑定和动态绑定

    我们常用的一般是动态绑定:

    // 父组件new Vue({  data () {    return {       parentMsg: '来自父组件的数据'    }  }})// 子组件Vue.component('child', {  // 在 JavaScript 中使用 camelCase  props: ['myMessage'],  template: '{{ myMessage }}'})

    登录后复制

    显示:

    来自父组件的数据

    登录后复制

    一般绑定:

    // 父组件子组件获得的是: 字符串 'hello!'

    登录后复制

    具体见:这里

    .sync 修饰符(2.3.0+新增)

    之前在 2.0 版本中移除后,在 2.3.0 中又加上了,只是调用的逻辑发生了变化,变成了一种语法糖。
    如下代码:

    
    

    登录后复制

    会被扩展为:

     bar = val">

    登录后复制

    当子组件需要更新 foo 的值时,它需要显式地触发一个更新事件:

    this.$emit('update:foo', newValue)

    登录后复制

    有点类似与 v-model

    具体见:这里

    自定义组件的 v-model(2.2.0 新增)

    默认情况下,一个组件的 v-model 会使用 value prop 和 input 事件。这也是之前 v-model 默认绑定的元素 和 事件方法。

    但是到 2.2.0 时候,我们可以通过 model 配置这个两个属性。

    Vue.component('my-checkbox', {  model: {    prop: 'checked',    event: 'change'  },  props: {    checked: Boolean,    // 这样就允许拿 `value` 这个 prop 做其它事了    value: String  },  // ...})

    登录后复制

    
    

    登录后复制

    上述代码等价于:

     { foo = val }"  value="some value">

    登录后复制

    具体见:这里

    插槽内容分发

    我们不总能遇见我们的组件中包含了哪些元素,这时候我们在开发组件的时候,需要让这部分内容自定义。
    假定 my-component 组件有如下模板:

    我是子组件的标题

    只有在没有要分发的内容时才会显示。

    登录后复制

    父组件模板:

    我是父组件的标题

    这是一些初始内容

    这是更多的初始内容

    登录后复制

    渲染结果:

    我是父组件的标题

    我是子组件的标题

    这是一些初始内容

    这是更多的初始内容

    登录后复制

    当然还有 具名插槽 、作用域插槽(2.1.0 新增)、slot-scope(2.5.0新增)

    具体见:这里

    动态组件

    通过使用保留的 元素,并对其 is 特性进行动态绑定,你可以在同一个挂载点动态切换多个组件:

    var vm = new Vue({  el: '#example',  data: {    currentView: 'home'  },  components: {    home: { /* ... */ },    posts: { /* ... */ },    archive: { /* ... */ }  }})

    登录后复制

      

    登录后复制

    注意这里的 is 与 之前说的 v-bind:is 别混淆

    具体见:这里

    对低开销的静态组件使用 v-once

    尽管在 Vue 中渲染 HTML 很快,不过当组件中包含大量静态内容时,可以考虑使用 v-once 将渲染结果缓存起来,就像这样:

    Vue.component('terms-of-service', {  template: '    

    Terms of Service

    ...很多静态内容...
    '})

    登录后复制

    具体见:这里

    混合(mixins)的合并策略

    周期钩子的合并策略

    同名钩子函数将混合为一个数组,因此都将被调用

    混合对象的钩子将在组件自身钩子 之前 调用

    var mixin = {  created: function () {    console.log('混合对象的钩子被调用')  }}new Vue({  mixins: [mixin],  created: function () {    console.log('组件钩子被调用')  }})// => "混合对象的钩子被调用"// => "组件钩子被调用"

    登录后复制

    methods, components 和 directives 的合并策略

    两个对象键名冲突时,取组件对象的键值对

    var mixin = {  methods: {    foo: function () {      console.log('foo')    },    conflicting: function () {      console.log('from mixin')    }  }}var vm = new Vue({  mixins: [mixin],  methods: {    bar: function () {      console.log('bar')    },    conflicting: function () {      console.log('from self')    }  }})vm.foo() // => "foo"vm.bar() // => "bar"vm.conflicting() // => "from self"

    登录后复制

    以上就是Vue中一些重要的知识点的详细内容,更多请关注【创想鸟】其它相关文章!

    版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

    发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2786499.html

    (0)
    上一篇 2025年3月8日 17:46:01
    下一篇 2025年2月26日 17:26:59

    AD推荐 黄金广告位招租... 更多推荐

    相关推荐

    • JavaScript事件解析

      事件是在编程时系统内发生的动作或者发生的事情.系统通过它来告诉编程者,在编程者愿意的情况下,编程者一某种方式对它做出回应.本文主要和大家分享JavaScript事件解析,希望能帮助到大家。 添加事件方式 元素属性 var btn = doc…

      2025年3月8日
      200
    • JS实现图片轮播的实例

      本文主要为大家带来一篇使用js实现图片轮播的实例(前后首尾相接),代码参考了一位已经写好了图片轮播功能的(再次表示感谢),但是没有首尾相接的功能,本人在此基础上增加了首尾相接功能。 效果如下: nbsp;html PUBLIC “-//W3…

      2025年3月8日
      200
    • Node调用Java的示例代码分享

      java 端作为服务提供者,基于dubbo 实现服务并通过 dubbo hessian 扩展暴露服务;node 端作为服务消费者,通过node-hessian 调用 java 端的服务。本文主要和大家介绍了node调用java的示例代码,小…

      2025年3月8日
      200
    • react前后端同构渲染示例代码

      前后端同构渲染:当客户端请求一个包含react组件页面的时候,服务端首先响应输出这个页面,客户端和服务端有了第一次交互。然后,如果加载组件的过程需要向服务端发出ajax请求等,客户端和服务端又进行了一次交互,这样,耗时相对较长。前后端同构渲…

      2025年3月8日
      200
    • 微信页面弹出键盘后iframe内容变空白

      本文主要和大家分享微信页面弹出键盘后iframe内容变空白的解决办法。当键盘弹出后,页脚也被顶起来;而当搜索完(要刷新整体页面),键盘缩回后,iframe里 键盘当住的地方变成白色。 前言: 因为iframe要适配,so,高度要计算出来 /…

      2025年3月8日
      200
    • JavaScript数组进化与性能分析实例

      在使用 javascript 前,我对 c、c++、c# 这些已经颇为熟悉。与许多 c/c++ 开发者一样,javascript 给我的第一印象并不好。本文主要和大家介绍了javascript 数组的进化与性能分析,本文讲得更多的是内存、优…

      2025年3月8日
      200
    • js高效率服务器时间同步实例

      本文主要和大家分享一个js倒计时的功能代码,首先说一下,为什么要服务器时间同步, 因为服务器时间和本地电脑时间存在一定的时间差。有些对时效性要求非常高的应用,例如时时彩开奖,是不能容忍这种时间差存在的。 方案1:每次倒计时去服务端请求时间 …

      编程技术 2025年3月8日
      200
    • js中Date()日期函数浏览器兼容问题如何解决

      一般直接new date() 是不会出现兼容性问题的,而 new date(datetimeformatstring) 常常会出现浏览器兼容性问题,为什么,datetimeformatstring中的某些格式浏览器不兼容。本文主要和大家介绍…

      编程技术 2025年3月8日
      200
    • JS鼠标3次点击事件的实现代码

      这几天看了一下javascript高级程序设计中的dom事件相关内容,同时看到网上有关鼠标多次点击事件,鼠标事件是简单、常用的事件之一,于是便针对点击事件进行一些小的扩展和实现,增强对dom事件的进一步理解。其中的实现和思路是自己总结的,有…

      编程技术 2025年3月8日
      200
    • js实现1,2,3,5数字按照概率生成代码分享

      本文主要和大家介绍了js实现1,2,3,5数字按照概率生成,需要的朋友可以参考下,希望能帮助到大家。 js按照配置的概率生成,概率规则如下:1————50% 2——&#…

      编程技术 2025年3月8日
      200

    发表回复

    登录后才能评论