用HTML DOM实现有条件地渲染网页元素(上)

简介: 用HTML DOM实现有条件地渲染网页元素(上)

0 前言

在  关于Vue学习笔记6中纯JavaScript实现的改进优化1_PurpleEndurer@5lcto的技术博客_51CTO博客 中,我们提到了两个进一步优化的方向,其中一个方面是把表示水果的选项信息存在一个数组里,通过JavaScript输出<li>元素描述代码给用户进行选择,这个我们已经在 关于Vue学习笔记6中纯JavaScript实现的改进优化2_PurpleEndurer@5lcto的技术博客_51CTO博客中实现。

现在我们就来实现另一个优化的方向:增加文本框,允许用户输入自己喜欢的水果名称,并添加到水果选项列表中。

1 比较两种实现方法

要实现动态添加网页元素,有两种方法,一种方法是直接向容器的innerHTML追加代码,另一种方式是通过HTML DOM。

这两种方法各有利弊:

直接向容器的innerHTML追加代码的方法,实现起来修改不多,可以以较快的速度来完成,但今后维护更新不方便。

通过HTML DOM来动态添加网页元素的方法,要修改的地方较多,改动范围较大,但今后维护比较容易。

权衡利弊,我们决定先使用第2种方法——HTML DOM。

首先我们要使用HTMLDOM 完成原来代码的改造。

2 引入HTML DOM

我们以  关于Vue学习笔记6中纯JavaScript实现的改进优化2_PurpleEndurer@5lcto的技术博客_51CTO博客中的代码

<script>
  function showFruit(v)
  {
  //var oUL =  document.getElementById('ulFruit');
  //alert(oUL.childElementCount);
  var coLi = document.getElementById('ulFruit').children;
  //alert(coLi.length);
  for (var i = 0; i < coLi.length; i++)
  {
    //alert(coLi[i].title);
    coLi[i].style.display = (v==coLi[i].innerText ? "list-item" : "none");
  } // for
  } // showFruit(v)
var aFruits = new Array(['苹果', 'Apple', 'red'],
    ['桔子', 'Orange', 'orange'],
    ['葡萄', 'Grape', 'purple'],
      ['芒果','Mango','yellow'],//增加芒果信息
      ['其它', 'Other', 'blue']);
function genFruitOption()
{
  for (var i=0; i<aFruits.length; i++)
  {
  document.write('<p><label><input type="radio"value="',
                  aFruits[i][0],
                  '" name="fruit" onchange="showFruit(this.value)" />',
                  aFruits[i][0],
                  '</label></p>');
  } //for
} //genFruitOption()
function genFruitLi()
{
  for (var i=0; i<aFruits.length; i++)
  {
  document.write('<li id="li',  
    aFruits[i][1],
    '" style="color:',
    aFruits[i][2],
    '">',
    aFruits[i][0],
    '</li>');
  } //for  
} //genFruitLi()
</script>
<p>用JavaScript响应click事件有条件地渲染网页元素</p>
<p>(使用数组存储水果信息)</p>
<p style="margin-left:20%; color:purple; font-weight:bold;">
  by PurpleEndurer
</p>
<p>你喜欢哪种水果?</p>
<script>
  genFruitOption();
</script>
<p>你喜欢的是:</p>
<ul id="ulFruit">
<script>
  genFruitLi();
</script>
</ul>


为基础进行改造。

2.1 修改网页元素描述代码

我们只需要修改2个地方。

2.1.1 修改技术改进说明

将  

<p>(使用数组存储水果信息)</p>


改为

<p>(引入HTML COM技术改造)</p>


2.1.2 为用户水果选项增加容器

为了实现用户水果选项网页元素的动态添加,我们需要把用户水果选项网页元素描述代码放在一个容器中,最简单的实现办法就是在用户水果选项网页元素描述代码套上<div id="divFruit"></div>,即将

<p>你喜欢哪种水果?</p>
<script>
  genFruitOption();
</script>

改为:

<p>你喜欢哪种水果?</p>
<div id="divFruit">
<script>
  genFruitOption();
</script>
</div>

需要注意的是,我们为新增加的<div>容器指定了id为"divFruit"。这个id我们在改造genFruitOption()时会用到。

2.2 修改JavaScript脚本

改造主要集中在JavaScript脚本这块。

2.2.1 修改genFruitOption()

在genFruitOption()中,原来只有一个for语句循环,其中的循环体是使用document.write函数直接输入页面元素描述代码。

 

document.write('<p><label><input type="radio"value="',
                  aFruits[i][0],
                  '" name="fruit" onchange="showFruit(this.value)" />',
                  aFruits[i][0],
                  '</label></p>');

这里涉及到<p><label>和<input>三个页面元素。

2.2.1.1 增加网页元素对象变量定义

现在用HTML COM来实现,首先我们要为<p><label>和<input>三个页面元素增加对象变量的定义,同时给id为'divFruit'的div的也增加一个对象变量的定义,即增加以下4行代码:

var oDivFruit = document.getElementById('divFruit');
  var oP;//<p>对象
  var oIn;// <input>对象
  var oLa;// <label>对象

2.2.1.2 修改 for语句的循环体

我们要使用HTML COM技术增加每个用户水果选项对应的网页元素,包括<p><label>和<input>。

即是将:

for (var i=0; i<aFruits.length; i++)
  {
  document.write('<p><label><input type="radio"value="',
                  aFruits[i][0],
                  '" name="fruit" onchange="showFruit(this.value)" />',
                  aFruits[i][0],
                  '</label></p>');
  } //for

相应地改为:

for (var i=0; i<aFruits.length; i++)
  {
  //创建<p>
  oP = document.createElement("P");
   
      //创建<input type="raido">
  oIn = document.createElement("input");
  oIn.type = 'radio';   //类型
  oIn.name = "fruit";   //
  oIn.id = 'ra' + aFruits[i][1];  //id
  oIn.value = aFruits[i][0];  //值
      oIn.addEventListener("click", showFruit); //增加click事件监听器
  //创建<label>
  oLa = document.createElement('label')
  oLa.htmlFor = 'ra' + aFruits[i][1];
  oLa.appendChild(document.createTextNode(aFruits[i][0]));
      //向<div>容器追加网页元素<P><input><label>对象
  oDivFruit.appendChild(oP);
  oDivFruit.appendChild(oIn);
  oDivFruit.appendChild(oLa);
  } //for

需要指出的是,使用HTML COM改造后,我们使用addEventListener函数来给用户水果选项对应的网页元素增加click事件监听器 showFruit,这个监听器有默认的输入参数,不再需要指定原来的输入参数this.value。

虽然改造后的代码,从行数来看,比之前多了许多,从10行变成了 23行,多了13行,不过代码更容易阅读,也更容易修改和维护了。

2.2.2 修改genFruitLi()

在genFruitLi()中,原来只有一个for语句循环,其中的循环体是使用document.write函数直接输入页面元素描述代码:

document.write('<li id="li',  
    aFruits[i][1],
    '" style="color:',
    aFruits[i][2],
    '">',
    aFruits[i][0],
    '</li>');

这里只涉及一个网页元素<li>。使用HTML COM改造也就比修改genFruitOption()容易一些。

2.2.2.1 增加网页元素对象变量定义

为了动态增加网页元素,我们需要增加<UL>和<LI>两个页面元素对象的定义:

var oUL =  document.getElementById('ulFruit');
  var oLi;

2.2.2.2 修改for语句的循环体

for (var i=0; i<aFruits.length; i++)
  {
  document.write('<li id="li',  
    aFruits[i][1],
    '" style="color:',
    aFruits[i][2],
    '">',
    aFruits[i][0],
    '</li>');
  } //for

改为

for (var i=0; i<aFruits.length; i++)
  {
  oLi = document.createElement("li");
  oLi.appendChild(document.createTextNode(aFruits[i][0]));
  oLi.style.color = aFruits[i][2]; //设置颜色
  oUL.appendChild(oLi);
  } //for  
1.

修改前的代码行数是13行,修改后的代码行数为仍然是13行(包括1个空行)。

2.2.3 修改监听器 showFruit()

修改前的监听器 showFruit(v)会显式地接收1个传入参数this.value。

在我们使用addEventListener函数来给用户水果选项对应的网页元素增加click事件监听器 showFruit后,这个监听器有默认的输入参数,这个参数的值和含义与显式地接收1个传入参数不同,所以我们一般用e来代表这个默认的输入参数。

2.2.3.1 修改函数输入参数

function showFruit(v)

改为

function showFruit(e)

2.2.3.2 修改函数体内使用传入参数的语句

由于使用HTML COM改造后的监听器函数传入参数的值和含义和之前不同,所以函数体内使用传入参数的语句要做相应的修改。

在showFruit()中,使用传入参数的语句只有一句,就是for语句循环体中用来控制水果元素显示的代码:

coLi[i].style.display = (v==coLi[i].innerText ? "list-item" : "none");

要改为:

coLi[i].style.display = (e.target.value==coLi[i].innerText ? "list-item" : "none");

也就是用 e.target.value 来代替原来的传入参数v。

至此,我们的改造就完成了。

3 改造后的最终代码

综合以上修改后的最终代码如下:

<script>
  function showFruit(e)
  {
  //var oUL =  document.getElementById('ulFruit');
  //alert(oUL.childElementCount);
  var coLi = document.getElementById('ulFruit').children;
  //alert(coLi.length);
  for (var i = 0; i < coLi.length; i++)
  {
    //alert(coLi[i].title);
    coLi[i].style.display = (e.target.value==coLi[i].innerText ? "list-item" : "none");
  } // for
  } // showFruit(v)
var aFruits = new Array(['苹果', 'Apple', 'red'],
    ['桔子', 'Orange', 'orange'],
    ['葡萄', 'Grape', 'purple'],
    ['芒果','Mango','yellow'],
    ['其它', 'Other', 'blue']);
function genFruitOption()
{
  var oDivFruit = document.getElementById('divFruit');
  var oP;//<p>对象
  var oIn;// <input>对象
  var oLa;// <label>对象
  for (var i=0; i<aFruits.length; i++)
  {
  //创建<p>
  oP = document.createElement("P");
   
    //创建<input type="raido">
  oIn = document.createElement("input");
  oIn.type = 'radio';   //类型
  oIn.name = "fruit";   //
  oIn.id = 'ra' + aFruits[i][1];  //id
  oIn.value = aFruits[i][0];  //值
    oIn.addEventListener("click", showFruit); //增加click事件监听器
  //创建<label>
  oLa = document.createElement('label')
  oLa.htmlFor = 'ra' + aFruits[i][1];
  oLa.appendChild(document.createTextNode(aFruits[i][0]));
    //向<div>容器追加网页元素<P><input><label>对象
  oDivFruit.appendChild(oP);
  oDivFruit.appendChild(oIn);
  oDivFruit.appendChild(oLa);
  } //for
} //genFruitOption()
function genFruitLi()
{
  var oUL =  document.getElementById('ulFruit');
  var oLi;
  for (var i=0; i<aFruits.length; i++)
  {
  oLi = document.createElement("li");
  oLi.appendChild(document.createTextNode(aFruits[i][0]));
  oLi.style.color = aFruits[i][2]; //设置颜色
  oUL.appendChild(oLi);
  } //for  
} //genFruitLi()
</script>
<p>用JavaScript响应click事件有条件地渲染网页元素</p>
<p>(引入HTML COM技术改造)</p>
<p style="margin-left:20%; color:purple; font-weight:bold;">
  by PurpleEndurer
</p>
<p>你喜欢哪种水果?</p>
<div id="divFruit">
<script>
  genFruitOption();
</script>
</div>  
<p>你喜欢的是:</p>
<ul id="ulFruit">
<script>
  genFruitLi();
</script>
</ul>

4 代码运行效果

image.png

5 小结

我们对原代码顺利完成了引入HTMLDOM 所需要的改造,尽管改造后有些地方的代码行数比原来有所增加。

但在更大型的应用系统中,这种改造不一定会增加代码行数。

改造之后,代码可读性更强,修改和维护效率将会得到提高。


相关文章
|
4月前
|
JavaScript 前端开发 开发者
Vue 动态添加 HTML 元素组件封装使用方法及长尾关键词优化指南
本文详细介绍了Vue中动态添加HTML元素的使用方法与组件封装技巧。内容涵盖条件渲染(v-if/v-show)、列表渲染(v-for)、动态组件(:is)、手动操作DOM及动态创建组件实例等核心方法。同时,通过动态表单、弹窗组件和动态加载组件的封装示例,展示如何提升代码复用性和可维护性。最后,总结性能优化策略与注意事项,如批量更新DOM、懒加载大型组件及避免直接操作DOM等,帮助开发者在实际项目中灵活应用Vue动态元素管理功能。
104 15
|
4月前
|
JavaScript 前端开发 开发者
Vue 动态添加 HTML 元素组件封装使用方法及长尾关键词优化指南
本文详细介绍了Vue中动态添加HTML元素的多种方法与组件封装技巧,涵盖条件渲染(v-if/v-show)、列表渲染(v-for)、动态组件(:is)、手动DOM操作及动态创建组件实例等内容。同时提供了性能优化建议,如批量更新DOM、使用v-show代替v-if以及懒加载大型组件等。通过合理封装组件,可提高代码复用性和维护性。文中还附有具体示例代码,帮助开发者更好地理解和应用相关技术。适用于前端开发人员学习和实践Vue动态元素处理与组件设计。
117 19
|
4月前
|
缓存 JavaScript 前端开发
Vue 项目中动态添加 HTML 元素的方法与实践
本文探讨了 Vue 中动态添加 HTML 元素的多种技术方案,包括条件渲染(v-if/v-show)、动态组件(component :is)、手动挂载($mount)及 Vuex 状态管理等方法。通过实例分析,如动态表单生成器与全局模态框服务,展示了这些方案在实际开发中的应用。同时提供了性能优化建议和注意事项,帮助开发者根据需求选择最佳方式,在保持 Vue 响应式特性的同时实现灵活交互。附带代码示例,便于理解和实践。
107 2
|
6月前
|
移动开发 前端开发 JavaScript
HTML5实现好看的劳动节网页源码
HTML5实现好看的劳动节网页源码,劳动节网页,劳动节网页源码,内置十个页面,各种模板都有,可以根据这些页面扩展更多页面,网页由网站首页、劳动节介绍、劳动节由来、劳动节习俗、劳动节文化、劳动节活动、劳动节故事、劳动节民谣、联系我们、登录/注册等页面组成,兼容手机端,页面干净整洁,内容丰富,可以扩展自己想要的,注释完整,代码规范,各种风格都有,代码上手简单,代码独立,可以直接运行使用。也可直接预览效果。
218 4
|
6月前
|
移动开发 HTML5
HTML5实现好看的中秋节网页源码
HTML5实现好看的中秋节网页源码,中秋节网页,中秋节网页源码,节日网页大作业,作业源码,内置十个页面,各种模板都有,可以根据这些页面扩展更多页面,网页由网站首页、中秋节介绍、中秋节由来、中秋节习俗、中秋节文化、中秋节美食、中秋节故事、中秋节民谣、联系我们、登录/注册等页面组成,兼容手机端,页面干净整洁,内容丰富,可以扩展自己想要的,注释完整,代码规范,各种风格都有,代码上手简单,代码独立,可以直接运行使用。也可直接预览效果。
352 0
HTML5实现好看的中秋节网页源码
|
7月前
|
移动开发 前端开发 JavaScript
HTML5实现好看的端午节网页源码
HTML5实现好看的端午节网页源码,包含十个页面:网站首页、端午节介绍、由来、习俗、文化、美食、故事、民谣、联系我们及登录/注册。页面设计简洁美观,内容丰富,兼容手机端,代码规范且注释完整,易于扩展和修改。提供完整的源码下载和视频演示,方便学习和使用。
230 3
|
7月前
|
存储 移动开发 JavaScript
网页 HTML 自动播放下一首音乐
在 HTML5 中实现自动播放下一首音乐,通过管理音乐列表、操作音频元素和监听事件完成。创建包含多个音乐链接的列表,使用 `&lt;audio&gt;` 元素加载音乐,监听 `ended` 事件,在当前音乐结束时自动播放下一首。示例代码展示了如何使用 JavaScript 实现这一功能,确保无缝切换音乐。
|
8月前
|
存储 JavaScript 算法
(html在线预览cad图纸插件)网页CAD绘制条形码、二维码的教程
本文介绍了如何在mxcad中绘制条形码和二维码。对于条形码,首先根据应用场景选择合适的编码标准(如CODE39、EAN13等),通过编码规则将数据转换为二进制,并利用`McDbHatch`绘制条和空的组合,同时支持自定义实体及属性管理。 对于二维码,因其能存储更多信息且具备更强纠错能力,采用开源库QRCode.js进行编码处理,再通过`McDbHatch`绘制黑白矩阵,同样封装成自定义实体以便管理和扩展。文中还给出了完整的绘制流程与效果展示,包括创建二维码对象、设置参数、调用绘制方法以及最终的效果图。整个过程体现了灵活运用API与第三方库来实现复杂图形绘制的能力。
|
9月前
HTML在线扫雷游戏网页源码
HTML在线扫雷游戏网页源码是一款基于HTML+CSS+JavaScript开发的在线扫雷小游戏单页源码,为用户提供了一个无需安装即可在浏览器中直接玩的扫雷游戏。该游戏的源码不仅包含了完整的游戏逻辑,还具备丰富的界面设计和用户交互功能,使得玩家能够轻松上手并享受扫雷带来的乐趣。
340 22
|
9月前
|
数据采集 前端开发 数据挖掘
利用 html_table 函数轻松获取网页中的表格数据
本文介绍了如何使用 R 语言中的 `html_table` 函数结合代理 IP 技术,轻松提取网页表格数据并规避反爬机制。通过设置代理和请求头,示例代码展示了如何从 58 同城采集租房信息并保存为 CSV 文件。该方法适用于需要频繁采集数据的场景,确保数据采集的高效和稳定性。
349 2
利用 html_table 函数轻松获取网页中的表格数据