Angular2如何修改父子组件样式

场景:需要根据实际项目需求,修改引入的第三方组件的部分样式

目录

  1. 修改父组件的元素的样式
  • 修改子组件的元素的样式
  • 依据父组件有无某个类,来修改组件本身的样式

一、修改父组件的元素的样式

:host

:host伪类,这是在组件内部获取到其宿主元素的唯一方式,会向上一直查找到根元素body

具体使用方法:

// 默认当前在一个组件中,该组件位于一个父组件中,且该组件引入了第三方子组件
// 以下内容为当前组件引用的css文件里的内容

// 第一种方式
// ele : 当前元素
ele:host h1 {
  font-size: 20px;
}
// 效果: 修改父组件的h1元素字体大小为20px。

// 第二种方式
ele:host(.active) h1 {
  font-size: 20px;
}
// 效果: 修改父组件类为active元素下的h1元素的字体大小。

二、 修改子组件的元素的样式

/deep/>>>

/deep/ 和 >>> 是一个意思两种写法,都是操作子组件的元素的。

具体使用方法:

ele /deep/ h1 {
  font-size : 16px;
}
// 效果:/deep/ 最好是写在一个元素后面, 不然编辑器lint会报红, 这里是查找子组件的h1元素,并修改它的字体大小

等同于:
ele >>> h1 {
  font-size : 16px;
}

三、 依据父组件有无某个类,来修改组件本身的样式

:host-context

:host-context,和:host类似,都是获取宿主元素,虽然都是查找宿主元素,但它们是有区别的, :host修改的还是宿主元素,:host-context修改却是当前组件,后者是针对父组件是否具备某个类名作出相应的样式改变响应。

具体使用方法:

ele:host-context(.active) h1 {
  border: 1px dotted #f00;
}
// 效果: 当宿主元素拥有active类时,才修改当前组件的h1元素的border属性样式。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,825评论 1 92
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,027评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,786评论 25 709
  • Sharding-JDBC是当当开源的分库分表中间件,通过重写jdbc api的方式为Java应用提供分库分表的能...
    Yuan2021阅读 5,751评论 1 8
  • 好像所有的故事,开头都有一个“在很久很久以前”...... 在很久很久以前,有一个森林王国,我忘记它的名字叫什么了...
    小野椰子阅读 711评论 0 2