当前位置: 首页 > news >正文

Web Components

Web Components标准非常重要的一个特性是,它使开发者能够将HTML页面的功能封装为custom elements(自定义标签),可以使用CustomElementRegistry来管理自定义标签

<script>//1、创建自定义标签class NewElement extends HTMLElement {constructor () {super();// 在此定义自定义标签// 创建一个shadow根标签let shadow = this.attachShadow({mode: 'open'});// 创建我们需要的标签let wrapper = document.createElement('div');let iconBox = document.createElement('div');let textBox = document.createElement('div');// 为标签添加样式wrapper.setAttribute('class', 'wapper');iconBox.setAttribute('class', 'icon');textBox.setAttribute('class', 'text');let text = this.getAttribute('text'); // 获取标签里面传递的值textBox.textContent = text;let imgUrl;if(this.hasAttribute('img')) {imgUrl = this.getAttribute('img');} else {imgUrl = 'default.png'; // 设置一个默认图片}var img = document.createElement('img');img.src = imgUrl;iconBox.appendChild(img);// 书写样式var style = document.createElement('style');let lStyleStr = '.wrapper { display: flex; justify-content: center; align-items: center; width: 100%; height: 50px;}';lStyleStr += '.icon {margin-right: 10px; width: 50px; height: 50px;}';lStyleStr += '.icon img { width: 100%; height: 100%;}';lStyleStr += '.text { flex: 1; font-size: 14px; color: #333; line-height: 50px;}';style.textContent = lStyleStr;// 将样式和dom元素挂载到页面shadow.appendChild(style);shadow.appendChild(wrapper);wrapper.appendChild(iconBox);wrapper.appendChild(textBox);}}//2、注册自定义标签customElements.define('new-element', NewElement);    
</script>//3、使用
<body><new-element img="you_picture.jpg" text="你的文字"></new-element>
</body>

 

http://www.lryc.cn/news/139500.html

相关文章:

  • IT运维软件的费用是多少?
  • 基于Three.js的WebXR渲染入门
  • resource doesn‘t have a corresponding Go package.
  • 【微服务】微服务调用原理及服务治理
  • 【在Windows下搭建Tomcat HTTP服务】
  • 前端Vue3框架知识点大全
  • C语言练习2(巩固提升)
  • Vulnhub: DriftingBlues: 1靶机
  • Android项目如何上传Gitee仓库
  • MySQL——基础——联合查询
  • Vue3+Vite 初始化Cesium
  • c++内存地址分配
  • 改进YOLO系列:9.添加S2Attention注意力机制
  • 微服务Feign组件远程调用自定义解码器
  • FairyGUI编辑器自定义菜单扩展插件
  • 若依二次开发
  • 安全(权限)框架Shiro概述及原理
  • java: 无法访问org.springframework.boot.SpringApplication 错误的类文件
  • 改进YOLO系列:7.添加CA注意力机制
  • Linux笔记--Ubuntu设置sftp服务
  • 火山引擎边缘云,助你沉浸式回忆童年
  • Axios跨域请求处理
  • Docker(二) Docker容器
  • 【业务功能篇81】微服务SpringCloud-ElasticSearch-Kibanan-docke安装-入门实战
  • 【UniApp开发小程序】私聊功能uniapp界面实现 (买家、卖家 沟通商品信息)【后端基于若依管理系统开发】
  • 【BASH】回顾与知识点梳理(三十六)
  • 十三、pikachu之暴力破解
  • 用手势操控现实:OpenCV 音量控制与 AI 换脸技术解析
  • 【leetcode 力扣刷题】移除链表元素 多种解法
  • leetcode503. 下一个更大元素 II 单调栈