Textarea与懒惰渲染实现代码

复制代码 代码如下:


<div>
立即渲染内容
<ul>
<li>张三<img src="https://www.jb51.net/p01.jpg"/></li>
<li>张四<img src="https://www.jb51.net/p02.jpg"/></li>
</ul>
</div>
<div>
<textarea>
懒惰渲染内容
<ul>
<li>李三<img src="https://www.jb51.net/p11.jpg"/></li>
<li>李四<img src="https://www.jb51.net/p12.jpg"/></li>
</ul>
</textarea>
</div>
<script>
setTimeout(function(){//懒惰渲染
var el =document.getElementById('lazyRender01');
el.parentNode.innerHTML = el.value;
},1000);
</script>


代码的好处是:让李三李四对应的内容,在懒惰渲染之前,不形成dom节点,不请求图片。
但有的同学会问:“Textarea里的内容,对搜索引擎不友好。”
没问题,这个也很好解决的:

复制代码 代码如下:


<div>
立即渲染内容
<ul>
<li>张三<img src="https://www.jb51.net/p01.jpg"/></li>
<li>张四<img src="https://www.jb51.net/p02.jpg"/></li>
</ul>
</div>
<div>
<script>document.write('<textarea>');</script>
懒惰渲染内容
<ul>
<li>李三<img src="https://www.jb51.net/p11.jpg"/></li>
<li>李四<img src="https://www.jb51.net/p12.jpg"/></li>
</ul>
</textarea>
</div>
<script>
setTimeout(function(){//懒惰渲染
var el =document.getElementById('lazyRender01');
el.parentNode.innerHTML = el.value;
},1000);
</script>


代码的区别很简单,只是把'<textarea>'这一段通过js的document.write输出来。
但结果却有了很大的不同:就算浏览器不支持js,一切内容也还是能原样显示出来。

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wdjjyw.html