Vue2中常用的属性和方法:

属性

  • el:用于指定Vue实例挂载的元素,可以是CSS选择器、HTML元素或Vue组件。
  • data:用于存储Vue实例的响应式数据,也可以是一个函数,返回一个对象,用于提供数据的初始化值。
  • computed:用于计算和返回基于Vue实例数据的派生属性,具有缓存功能。
  • watch:用于监听Vue实例的数据变化,执行相应的操作。
  • methods:用于定义Vue实例的方法,可以在模板中绑定事件使用。
  • props:用于接收父组件传递的数据,用于实现组件之间的通信。
  • components:用于定义全局或局部的Vue组件。
  • filters:用于定义Vue实例的过滤器,用于格式化文本、数字等数据。
  • template:用于指定 Vue 组件的模板,可以是一个字符串模板,也可以是一个 DOM 元素,甚至可以是一个 Vue 组件。

  • computed:计算属性对象,可以根据已有的数据计算出新的数据属性,与 data 数据属性不同的是,computed 属性是只读的。

  • directives:用于自定义指令,可以在 HTML 元素上添加自定义行为,如 v-focus 等。

  • mounted:Vue 实例挂载到 DOM 后自动调用的钩子函数,可以在该函数中进行 DOM 操作。

  • created:Vue 实例创建时自动调用的钩子函数,可以在该函数中进行一些初始化操作。

方法

  • $mount:手动挂载Vue实例,通常在使用Vue时不需要手动调用,Vue会自动调用该方法。
  • $watch:手动创建一个数据监听器,可以监听数据变化并执行相应的操作。
  • $nextTick:在DOM更新队列为空时调用指定的回调函数,通常用于在DOM更新后执行某些操作。
  • $emit:用于在Vue实例中触发自定义事件,并向父组件或子组件传递数据。
  • $on:用于在Vue实例中监听自定义事件,并执行相应的操作。
  • $set:用于给Vue实例动态添加响应式属性,通常用于在组件中动态添加数据。
  • $delete:用于删除Vue实例的响应式属性,通常用于在组件中删除数据。
  • $emit(event, [args]):触发当前组件的指定事件,并传递参数 args 给回调函数。

  • $on(event, callback):监听当前组件的指定事件,并注册回调函数 callback。

  • $nextTick(callback):在 DOM 更新后执行回调函数 callback。

  • $refs:用于访问组件中的子组件或 DOM 元素。

  • $set(object, key, value):用于给 Vue 数据对象中的属性设置新值。

  • $watch:监听数据变化并执行相应的回调函数。

  • $mount(el):手动挂载 Vue 组件到指定的 DOM 元素上。

  • $destroy():手动销毁 Vue 组件。

以下是一个简单的 Vue 示例,包括一些常用属性和方法,并做了注释:

<!-- index.html -->
<template>
<div>
<h1>{{ message }}</h1>
<input v-model="inputText" v-focus>
<p>computed property: {{ computedProp }}</p>
<button @click="incrementCounter">{{ counter }}</button>
<child-component :child-message="message" @child-event="handleChildEvent"></child-component>
</div>
</template> <script>
// 定义子组件
Vue.component('child-component', {
props: ['childMessage'],
template: '<div>{{ childMessage }} <button @click="$emit(\'child-event\')">emit child event</button></div>'
}); export default {
data() {
return {
message: 'Hello, Vue!',
inputText: '',
counter: 0
}
},
computed: {
computedProp() {
return this.message.toUpperCase();
}
},
directives: {
focus: {
inserted: function (el) {
el.focus();
}
}
},
mounted() {
console.log('mounted');
},
created() {
console.log('created');
},
methods: {
incrementCounter() {
this.counter++;
},
handleChildEvent() {
console.log('child event emitted');
}
}
};
</script>

在这个示例中,我们使用了 <template> 标签来定义视图模板,使用了 <script> 标签来定义 Vue 实例的选项对象。其中:

  • data 属性返回一个包含 messageinputTextcounter 三个响应式数据属性的对象;
  • computed 属性返回一个包含 computedProp 计算属性的对象,用于根据 message 计算出一个新的数据属性;
  • directives 属性包含了一个自定义指令 v-focus,用于使输入框自动获取焦点;
  • mountedcreated 钩子函数,分别在 Vue 实例挂载到 DOM 后和创建时自动调用;
  • methods 属性包含了 incrementCounterhandleChildEvent 两个方法,分别用于更新计数器和处理子组件的自定义事件;
  • 子组件 child-component,包含了一个 childMessage 属性和一个自定义事件 child-event

在模板中,我们使用了 {{ message }}v-model 指令来绑定数据属性 messageinputText,使用了 v-focus 自定义指令来使输入框自动获取焦点,使用了 computedProp 来显示计算后的数据属性值,使用了 @click@child-event 来监听按钮点击和子组件的自定义事件。

vue全家桶进阶之路14:常用属性和方法的更多相关文章

  1. Vue 全家桶 + Electron 开发的一个跨三端的应用

    代码地址如下:http://www.demodashi.com/demo/11738.html GitHub Repo:vue-objccn Follow: halfrost · GitHub 利用 ...

  2. 升级vue全家桶过程记录

    背景 如果你使用了element-ui的el-tabs组件,并且想要单独升级element-ui至2.10.0,你会发现,使用了el-tabs组件的页面只要打开就卡死.原因是element-ui~2. ...

  3. Vue全家桶高仿小米商城

    大家好,我是河畔一角,时隔半年再次给大家带来一门重量级的实战课程:<Vue全家桶高仿小米商城>,现在很多公司都在参与到商城的构建体系当中,因此掌握一套商城的标准开发体系非常重要:商城的开始 ...

  4. vue证明题一,vue全家桶的构成

    简单说下vue的构成,当然是简单为主,网上这东西满天飞,简单说几句就ok 1.vue是什么 vue读作view,是一种js框架.只关注于视图层,操作内容包括js,html,css 2.vue全家桶是什 ...

  5. 用 Vue 全家桶二次开发 V2EX 社区

    一.开发背景 为了全面的熟悉Vue+Vue-router+Vuex+axios技术栈,结合V2EX的开放API开发了这个简洁版的V2EX. 在线预览 (为了实现跨域,直接npm run dev部署的, ...

  6. Vue全家桶

    简介 “简单却不失优雅,小巧而不乏大匠”. Vue.js 是一个JavaScriptMVVM库,是一套构建用户界面的渐进式框架.它是以数据驱动和组件化的思想构建的,采用自底向上增量开发的设计. 为什么 ...

  7. 从零开始系列之vue全家桶(3)安装使用vuex

    什么是vuex? vuex:Vue提供的状态管理工具,用于同一管理我们项目中各种数据的交互和重用,存储我们需要用到数据对象. 即data中属性同时有一个或几个组件同时使用,就是data中共用的属性. ...

  8. 使用vue全家桶制作博客网站

    前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue.vue-router.vuex.v ...

  9. 转载: 使用vue全家桶制作博客网站 HTML5 移动网站制作的好教程

    使用vue全家桶制作博客网站   前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue. ...

  10. Vue全家桶介绍

    一直不清楚全家桶是什么玩意,上网搜了一下,才知道就是平时项目中使用的几个依赖包,下面分享一下 Vue 全家桶介绍 Vue有著名的全家桶系列,包含了vue-router(http://router.vu ...

随机推荐

  1. Java笔记第三弹

    Map集合的获取功能 V get(Object key);//根据键获取值 Set<K> keySet();//获取所有键的集合 Collection<K> values(); ...

  2. 2020杭电多校第四场 Go Running 最小点覆盖等于二分图最大匹配数

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6808 思路:刚开始也是乱想,想几下就忍不住画个t-x图像,然后每个点有两种可能,一是向西跑,一是向东跑 ...

  3. HTTP 返回状态码403,404,502等不同报错原因及解决思路

    要学会看日志rpm的默认路径 /var/log/nginx/源码的默认路径 安装路径/logs/ 排错思路: 1)服务器启动失败,直接"nginx -t"测试语法   看配置文件是 ...

  4. 多线程基础之CAS、AQS、ABA辨析

    这三个单词算是多线程面试常见的问题了,也是很多小白不太懂的问题,这里给出我的理解来. 一.CAS J.U.C 并发包中的很多类都涉及到了 CAS,可以说没有 CAS 和 volatile 就没有 J. ...

  5. 重磅!AWS升级对Apache Hudi的集成

    全球最大云厂商AWS的 Athena 团队又更新了 Athena 与 Apache Hudi 的集成,以支持新功能及最新的 0.8.0 社区版本.早在Apache Hudi还处于孵化阶段时,AWS A ...

  6. 非线性规划—R实现

    非线性规划 非线性规划是一种求解目标函数或约束条件中有一个或几个非线性函数的最优化问题的方法.运筹学八大分支之一,20世纪50年代初,库哈(H.W.Kuhn) 和托克 (A.W.Tucker) 提出了 ...

  7. 华为人工智能atlasA800-9000物理服务器离线安装及CANN安装和MindSpore安装和Tensorflow安装

    目录 华为人工智能atlas A800-9000 物理服务器全程离线安装驱动以及CANN安装部署和MindSpore安装部署和Tensorflow安装部署 A800-9000 物理服务器安装驱动 使用 ...

  8. LeeCode 二叉树问题(三)

    二叉树的应用问题 LeeCode 222: 完全二叉树的节点个数 题目描述 给你一棵 完全二叉树 的根节点 root,求出该树的节点个数. 完全二叉树的定义 除最底层节点可能没填满外,其余每层节点树都 ...

  9. Springboot集成MongoDB存储文件、读取文件

    一.前言和开发环境及配置 可以转载,但请注明出处. 之前自己写的SpringBoot整合MongoDB的聚合查询操作,感兴趣的可以点击查阅. https://www.cnblogs.com/zaoyu ...

  10. 【Spring5】数据库事务操作

    Spring针对事务的操作 事务的概念:事务是数据库最基本的单元,逻辑上的一组操作,要么都成功,如果有一个操作失败则都失败. 事务的特性:ACID 原子性.一致性.隔离性.持久性 JavaEE环境三层 ...