我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解Vue进阶构造属性

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解Vue进阶构造属性

1、Directive 自定义指令

在 Vue 框架下的代码中,很少用到原生 DOM 操作,那是因为在 Vue 中将原生 DOM 操作都封装成了指令,例如我们前面见到的 <div v-text="xxx"></div> 指令,其实其内部操作就是:

div.innerText = xxx; //当然这里的 div 是获取得来的 DOM 元素

Vue 将原生 DOM 操作封装成指令,那个元素想使用该指令,直接在 HTML 模板中的元素标签中当作属性使用就行,简介方便,减少重复。

但是 Vue 毕竟不能把所有 DOM 操作情况都提前考虑进去封装成对应指令,有些 DOM 操作还得开发者在实际中用到时才知道,因此 Vue 便提供了用户自定义指令的方式,大致分为如下两种:

自定义指令和自定义组件类似,也分为全局和局部,下面以自定义一个打印字符 y 的指令 v-y为例讲解:

全局指令

全局属性就是在 Vue 提供的特定函数中注册:


Vue.directive("y", {
  inserted: function(el) {
    el.addEventListener("click", () => console.log("y"));
  }
});

局部指令

只能用在定义该指令的 template 里

可以是完整版的 template 属性里

main.js


new Vue({
  template:`
    <div v-y>
      <button>点击</button>
    </div>
  `,
  directives:{
    'y':{
      inserted: function(el) {
        el.addEventListener("click", () => console.log("y"));
      }
    }
  }
}).$mount("#app");

或者是非完整版的 .vue 文件的 export default{}里

app.vue


<template>
    <div>
      <button v-y>点击</button>
    </div>
</template>
<script>
    export default {
      directives:{
        'y':{
          inserted: function(el) {
            el.addEventListener("click", () => console.log("y"));
          }
        }
      }
    };
</script>

directiveOptions

指令对象里有5个函数属性


{
    bind: function (el,info,vnode,oldVnode) {}, //元素创建在内存中时执行
    inserted: function (参数同上) {}, //元素插入页面时执行
    update: function (参数同上) {}, 
    componentUpdated: function (参数同上) {}, 
    unbind: function (参数同上) {} //元素消失时执行
}

函数属性的参数中 el 是指调用该指令的元素,info 包含了所有信息,需要时就在 info 中找

2、Mixin 混入

混入的主要目的是为了减少构造选项的重复,可将重复的构造选项的部分抽离出来放到一个单独的 *.js 文件中,然后用 import 导入,再在构造选项中通过 mixins 属性混入。

minxin 是智能混合,会根据添加的混入和当前的选项进行智能混合,而不是单纯的复制。

3、Extends 继承

继承和 minxin 功能差不多,但 extend 更抽象些,二者都是对构造选项的重复进行简化,extend 可以在原有 Vue 的空壳基础上加上自己的定义属性作为固定属性,然后在创建 Vue 对象时使用创建继承了 Vue 的自定义类 MyVue。

MyVue.js


const MyVue = Vue.extend({
    minxins: [log]
});

export default MyVue;

4、provide 和 inject

父代提供共用数据或方法


{
    //...
    provide(){
        return {
            xx: this.changexx,
            yy: this.changeyy
        }
    },
    methods:{
        changexx(){
            //...
        },
        changeyy(){
            //...
        }
    }
}

后代注入东西对数据修改


{
    inject: ["changexx", "changeyy"]
}

和 .sync 修饰符的作用有点像,但比 .sync 要广泛。

以上就是详解Vue进阶构造属性的详细内容,更多关于Vue进阶构造属性的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解Vue进阶构造属性

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue进阶构造属性的示例分析

小编给大家分享一下Vue进阶构造属性的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、Directive 自定义指令在 Vue 框架下的代码中,很少用到
2023-06-15

【程序员必备】VUE 计算属性的进阶指南

计算属性是 Vue 中一种强大的工具,它允许您定义根据其他响应式属性计算的属性。本指南将深入探讨 Vue 计算属性的进阶用法,帮助程序员掌握其全部潜力。
【程序员必备】VUE 计算属性的进阶指南
2024-02-20

VUE计算属性进阶指南:探索计算属性的更多高级用法

在Vue.js中,计算属性是一个极其强大的工具,它可以让开发者轻松获取基于其他响应式属性的衍生数据,从而避免了复杂的表达式及其维护工作。本文将带您深入探索计算属性的更高级用法,通过演示代码示例帮助您掌握计算属性的精髓。
VUE计算属性进阶指南:探索计算属性的更多高级用法
2024-02-27

VUE计算属性:从初学者到专家的进阶指南

计算属性是Vue.js中一种强大的工具,它允许您在不使用任何方法的情况下轻松地从组件数据创建新的属性。本文将为您提供有关Vue.js计算属性的完整指南,从初学者到专家。
VUE计算属性:从初学者到专家的进阶指南
2024-02-27

关于Vue中的计算属性和监听属性详解

这篇文章主要介绍了关于Vue中的计算属性和监听属性详解,Vue.js模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的,在模板内放入过长的或复杂的逻辑时,会让模板过重且难以维护,需要的朋友可以参考下
2023-05-20

编程热搜

目录