Vue学习计划-Vue2--VueCLi(三)ref属性、mixins混入、插件、scoped样式

本文主要是介绍Vue学习计划-Vue2--VueCLi(三)ref属性、mixins混入、插件、scoped样式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. ref属性

  1. 被用来给元素或子组件注册引用信息(id的替代者)
  2. 应用在html标签上获取的是真实DOM元素,应用在组件标签上是组件实例对象(VC(VueComponent))
  3. 使用方式:
    1. 打标识<h1 ref="xxx">.....</h1>或者<School ref="xxx"></School>
    2. 获取:this.$refs.xxx

示例: 我们只需要两个组件,父组件APP.vue,子组件MyCount.vue,需求:父组件操作子组件内的数据与方法
1. 文件目录:components文件夹内创建MyCount.vue文件
在这里插入图片描述

  1. MyCount.vue中,写代码:

    注意:data中写数据,必须是函数
    在这里插入图片描述

  2. App.vue文件中引入MyCount.vue在这里插入图片描述
  3. 页面中展示效果:
    在这里插入图片描述
  4. 效果分析:
  1. 初始值count为10,表示10人观看
  2. 点击按钮有人走了(子组件内部控制count),人数减少
  3. 点击按钮来人了(父组件内需要操作组件内部数据),人数增加
  4. 可以看到App.vue内部引入的MyCount标签上添加了ref属性,methods内部的事件也输出了this.refs.MyCount,控制台输出结果为:
    在这里插入图片描述
    可以看出,this.$refs.MyCount直接输为MyCount组件,所以可直接this.$refs.MyCount.count++;改变子组件的数据

2. mixin(混入/共享)

  • 功能: 可以把多个组件共用的配置提取成一个混入对象
  • 使用方式:
1. 第一步定义混合,例如:
{data(){...}methods:{....}...
}
2. 第二步使用混入:例如:(1). 全局混入:Vue.mixin(xxx)(2). 局部混入: mixins:['xxx']

示例:我们需要4个组件,父组件APP.vue,子组件MySchool.vue,MyStudent.vue,mixins.js,需求:MySchool.vueMyStudent.vue两个组件内有同样的方法和数据,可否优化?

  1. App.vue组件引入两个组件
    在这里插入图片描述

  2. MySchool.vue组件内部:
    在这里插入图片描述

  3. MyStudent.vue组件内部:
    在这里插入图片描述

  4. App.vue同级创建mixins文件夹,新建mixins.js
    在这里插入图片描述

  5. 效果分析:

  1. 每个组件内部都有数据name和方法outPut,我们可以创建共享文件mixins.js实现共享,(data、computed、methods等
  2. 若组件内部有同名的数据,优先级会更高在这里插入图片描述

3. 插件

  1. 功能: 用于增强Vue
  2. 本质: 包含install方法的一个对象,install的第一个参数是Vue,第二个以后的参数是插件使用者传递的数据
  3. 定义插件:
对象.install = function(Vue, options){// ......全局过滤器,全局指令,配置混入// 添加实例方法Vue.prototype.$myMethods = funciton () {}Vue.prototype.$myProperty = funciton () {}
}
  1. 使用插件:
    Vue.use()

4. scoped样式

  • 作用: 让样式在局部生效,防止冲突(只控制本组件及以下样式)
  • 写法:<style scoped>
    示例:准备两个组件,父组件App.vue和子组件MySchool.vue,需求:子组件内写样式不影响父组件的样式
  1. 父组件App.vue:
    在这里插入图片描述

  2. 子组件MySchool:
    在这里插入图片描述

  3. 实际效果:子组件内写样式,影响父组件了
    在这里插入图片描述

  4. 加上scoped:
    在这里插入图片描述

  5. 效果显示:并未影响在这里插入图片描述

这篇关于Vue学习计划-Vue2--VueCLi(三)ref属性、mixins混入、插件、scoped样式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/483225

相关文章

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

spring中的@MapperScan注解属性解析

《spring中的@MapperScan注解属性解析》@MapperScan是Spring集成MyBatis时自动扫描Mapper接口的注解,简化配置并支持多数据源,通过属性控制扫描路径和过滤条件,利... 目录一、核心功能与作用二、注解属性解析三、底层实现原理四、使用场景与最佳实践五、注意事项与常见问题六

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

python删除xml中的w:ascii属性的步骤

《python删除xml中的w:ascii属性的步骤》使用xml.etree.ElementTree删除WordXML中w:ascii属性,需注册命名空间并定位rFonts元素,通过del操作删除属... 可以使用python的XML.etree.ElementTree模块通过以下步骤删除XML中的w:as

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)