You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

使用JavaScript动态指定CSS属性名修改元素样式时变量失效问题求助

解决动态修改CSS属性的问题

嘿,我一眼就看出问题出在哪啦!你当前的代码里,style.type是在直接访问style对象上名为type的固定属性,而不是把你传入的type变量值当作属性名来用——这就是为啥变量传参没生效的原因。

在JavaScript里,要动态使用变量作为对象属性名,得用方括号[]语法,而不是点.语法。点语法只能识别固定的属性字符串,没法解析变量。

给你修改好的代码:

function style(name, type, value) {
  document.getElementById("CreateMenu").style[type] = value;
}

举个实际调用的例子,比如你想把元素的背景色改成蓝色,就这么调用:

style('menu', 'backgroundColor', 'blue');

这里要注意个小细节:CSS里带短横线的属性名(比如background-color),在JS的style对象里得写成驼峰式backgroundColor,不然会不生效哦。

内容的提问来源于stack exchange,提问作者Silas Mikkelsen

火山引擎 最新活动