javascript - js中 加等于的累加赋值问题求解
问题描述
第一张图片 我能理解 在变量a中 +=过后 a的值是18
第二张图片 我首先创建了一个style的标签(第一个红线),然后再style标签中赋予新的属性和值,如果第一个赋值我可以用等于,但是其后的赋值我必须要用加等于才能让前面的赋值不会被覆盖,等于是做了一个累加操作,(后面的三四根红线是+=,第二根是等于),那为什么第一种图片的变量a最后的值是多次累加后的值,而第二种的是累加且依次展现,这个+=的累加逻辑是怎么表达的?
问题解答
回答1:第一个是数字累加,第二个累加相当于拼接字符串,你可以换成模板字符串的方式,处理起来比较方便,如下所示。
var cssNode=document.createElement(’style’);var middle=’b’;cssNode.innerHTML=’a’;cssNode.innerHTML+= `--- ${middle}----`;cssNode.innerHTML+=’c’;console.log(cssNode.innerHTML);//输出: a--- b----c回答2:
第一种是数字,+ 相当于加法。
第二种是字符串,+ 相当于连接。
回答3:没太懂你想表达什么,就最后一句话的回答:a+=b就相当于a = a + b
回答4:cssNode.innerHtml += “...”; 等同于cssNode.innerHtml = cssNode.innerHtml +'...'。而每次改变innerHtml都会重发html元素的重绘(严格的说,包括重排和重绘,对应的英文reflow和repaint)这就是问什么依次展现
如果想最终展现一次,就定义一个变量例如myInnerHtml,对它做+=操作,最后给cssNode.innerHtml = myInnerHtml
回答5:先定义一个字符数变量,最后再赋值给innerHtml
相关文章:
1. android - 哪位大神知道java后台的api接口的对象传到前端后输入日期报错,是什么情况?求大神指点2. mac里的docker如何命令行开启呢?3. css3: dl中如何让dr和dt视觉上显示到同一行?4. javascript - 如何向localStorage上的数组push数据5. javascript - hbuilder做的app在边看边改模式页面能跳转,为什么到了手机端就不能跳转?6. css - jq有无现成函数改变rotateX/Y的deg7. vue添加锚点,实现滚动页面时锚点添加相应的class操作8. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?9. ddos - apache日志很多其它网址,什么情况?10. javascript - node引入文件路径中的@是什么意思?
