0

0

Vue如何实现组件嵌套和组件样式管理?

王林

王林

发布时间:2023-06-27 15:33:10

|

3414人浏览过

|

来源于php中文网

原创

vue.js 是一款轻量级的javascript 框架,它的特点是数据驱动、响应式更新视图。vue.js 的核心概念是组件化,组件可以是按钮、表单、模态框等等,可以自由组合,拆分成更小的组件。vue.js 的组件嵌套和样式管理是组件化开发中必备的知识点,本文将详细讲解如何在 vue 中实现组件嵌套和样式管理。

组件嵌套

组件嵌套是指将一个组件放置在另一个组件内部,形成父子组件关系,通过父组件向子组件传递数据,子组件也可以向父组件传递数据,从而实现组件之间的通信。Vue.js 实现组件嵌套非常方便,只需要在父组件内部引入子组件的模板即可。下面是一个简单的例子:



上面的代码是一个父组件,通过 import 引入子组件,然后在 components 中注册子组件,即可在父组件中使用子组件。在父组件中用 的方式引入子组件的模板,即可实现组件嵌套。

在子组件中,我们通常从父组件获取数据。Vue.js 中父子组件的数据传递主要通过 props$emit 两种方式实现。props 表示父组件向子组件传递数据,子组件通过接收 props 来获取父组件传递的数据。下面是一个简单的 props 例子:



上面的代码是一个子组件,通过 props 定义了一个名为 name 的属性,父组件向子组件传递数据时通过 name 属性进行传递。在子组件的模板中,可以通过 {{ name }} 的方式获取父组件传递的数据。

在父组件中向子组件传递数据时,可以通过 v-bind 指令传递数据。如下所示:



在父组件中,我们定义了一个名为 fatherName 的变量,用于存储父组件的名字。在子组件中,我们通过 props 来接收 fatherName

组件样式管理

组件样式管理是指在 Vue.js 中如何管理组件的样式,保证每个组件的样式不会互相影响,且易于维护。Vue.js 提供了两种方式来管理组件样式:作用域样式和 CSS Modules。

作用域样式

作用域样式是指在组件中使用 scoped 属性定义样式,使得该组件样式只对当前组件有效。例如:



在这个组件中,我们在样式标签上加上了 scoped 属性,即 style scoped。这样定义的样式只对当前的组件有效,不会影响其他组件或全局样式。

云模块网站管理系统3.1.03
云模块网站管理系统3.1.03

云模块_YunMOK网站管理系统采用PHP+MYSQL为编程语言,搭载自主研发的模块化引擎驱动技术,实现可视化拖拽无技术创建并管理网站!如你所想,无限可能,支持创建任何网站:企业、商城、O2O、门户、论坛、人才等一块儿搞定!永久免费授权,包括商业用途; 默认内置三套免费模板。PC网站+手机网站+适配微信+文章管理+产品管理+SEO优化+组件扩展+NEW Login界面.....目测已经遥遥领先..

下载

使用作用域样式有一个缺点:不支持深度选择器。在组件中,如果要使用深度选择器,必须在选择器前加上 /deep/ 或者 >>>,如下所示:



上面的代码中,我们在 .component 的样式定义中使用了 /deep/ .sub-component,在 .sub-title 的样式定义中使用了 >>>。这样就可以在作用域样式中定义深度选择器了。

CSS Modules

CSS Modules 是一种模块化 CSS 的解决方案,它可以将 CSS 模块化并命名,确保每个组件的样式都是独立的。Vue.js 提供了对 CSS Modules 的支持,我们可以在每个组件中使用独立的 CSS Module。

首先,我们需要安装 css-loaderstyle-loader,并在 Webpack 配置文件中添加关于 CSS Modules 的配置:

// webpack.conf.js
module.exports = {
  // ...
  module: {
    rules: [
      {
        test: /.css$/,
        loader: 'style-loader!css-loader?modules'
      },
      {
        test: /.vue$/,
        loader: 'vue-loader',
        options: {
          cssModules: {
            localIdentName: '[name]-[hash]',
            camelCase: true
          }
        }
      }
    ]
  }
  // ...
}

上面的代码中,我们在 css-loader 的配置中加上了 modules,表示启用 CSS Modules。在 vue-loader 的配置中加上了 cssModules 属性,表示在 Vue.js 的单文件组件中启用 CSS Modules。

在单文件组件中,我们可以通过 scoped 属性指定 CSS Module 名称。



上面的代码中,我们在 style 标签上加上了 module 属性,表示这是一个 CSS Module。在 CSS 中,我们可以采用传统的方式定义样式,不需要使用作用域样式或者深度选择器。

在组件中引入 CSS Module 时,需要使用 $style 对象,如下所示:



上面的代码中,我们使用 $style.title 引用了本组件中定义的 title 样式。

总结:Vue.js 提供了两种方式来管理组件样式:作用域样式和 CSS Modules。作用域样式适用于简单的样式,而 CSS Modules 适用于组件化的应用程序,它将 CSS 模块化并确保每个组件的样式都是独立的。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
vue.js为什么报错
vue.js为什么报错

vue.js报错的原因:1、语法错误;2、组件使用不当;3、数据绑定问题;4、生命周期钩子使用不当;5、插件或依赖问题;6、路由配置错误;7、异步操作处理不当等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

120

2024.03.11

vue.js插槽有哪些用
vue.js插槽有哪些用

vue.js插槽的作用:1、提高组件的可重用性;2、实现组件的灵活布局;3、实现组件间的数据传递和交互;4、促进组件的解耦和模块化。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

177

2024.03.11

vue.js怎么带参数跳转
vue.js怎么带参数跳转

vue.js带参数跳转的方法:1、定义路由;2、在组件中使用路由参数;3、进行带参数的跳转。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

92

2024.03.11

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

513

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5306

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

481

2023.09.01

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 7.3万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号