js setProrperty和setAttribute解析

今天深入学习h() 发现 它的第二个参数 和 setAttribute有些相似,所以写了这篇文章

MDN解释

MDN中setAttribute解释

Element 接口的 setAttribute() 方法用于设置指定元素上的某个属性值。如果属性已经存在,则更新该值;否则,使用指定的名称和值添加一个新的属性

js 复制代码
html:```
<button>你好,世界</button>
```
const button = document.querySelector("button");
// 设置属性
button.setAttribute("name", "helloButton");
button.setAttribute("disabled", "");

MDN中setProrprity解释

setProrprity方法接口为一个声明了 CSS 样式的对象设置一个新的值

js 复制代码
const declaration = document.style;
declaration.setProperty("margin", "1px 2px");
// 相当于:
// declaration.margin = '1px 2px';
方法 个人总结
setAttribute 设置属性 如:个人自定义属性、HTML属性(不推荐)
setProrperty 设置css样式(包括css变量 如:--y)

vue h()的第二个参数 与 setAttribute 相似之处

简单讲解一下 h() 创建vue虚拟节点

个人总结

h()的第二个参数和setProrperty类似地方是可以给对应的节点设置属性,但h()的第二个参数是个对象,对象值可以不是字符串,更方便优雅。

js 复制代码
    // setProrperty 设置点击事件和字体大小
    element.setAttribute('onClick', '(()=> { console.log("hello div") })()');//点击事件
    element.setAttribute('style', 'font-size:30px;'); // 字体大小

    //  h()第二个参数 设置点击事件和字体大小
  <component
   :is="h('div', {onclick: ()=> { console.log('hello h()') } ,style: { 'fontSize': '30px' },},'点击')">
  </component>

Ai总结

  1. 共同点
  • 都用于设置元素的属性和事件
  • 都可以处理标准 HTML 属性
  1. 主要区别
  • 语法结构

    • setAttribute 每次只能设置一个属性
    • h() 可以通过对象一次性设置多个属性
  1. 使用场景
  • setAttribute: 用于直接 DOM 操作
  • h(): 用于虚拟 DOM 的创建和渲染
相关推荐
橘子编程4 分钟前
React 19 全栈开发实战指南
前端·react.js·前端框架
DanCheOo5 分钟前
AI Streaming 架构:从浏览器到服务端的全链路流式设计
前端·agent
我是小趴菜11 分钟前
前端如何让图片、视频、pdf等文件在浏览器直接下载而非预览
前端
cg3315 分钟前
开源项目自动化:用 GitHub Actions 让每个 Issue 都被温柔以待
前端
haierccc25 分钟前
Win7、2008R2、Win10、Win11使用FLASH的方法
前端·javascript·html
We་ct28 分钟前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
柠檬味的Cat31 分钟前
使用腾讯云COS作为WordPress图床的实践
前端·github·腾讯云
Hilaku34 分钟前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试
非凡ghost35 分钟前
AIMP(音乐播放软件)
前端·windows·音视频·firefox
xiaotao13137 分钟前
Vite 完全学习指南
前端·vite·前端打包