首页 > 编程语言 >Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素

时间:2024-09-21 17:50:51浏览次数:19  
标签:Vue 网页 valueOf JavaScript 桔子 showFruit 苹果 yourFruit 2.1

0 缘起

有时我们的网页需要根据需要用户的选择展示不同的页面元素。

例如:

<p>你喜欢哪种水果?</p>
<p>
	<label>
		<input type="radio" value="苹果" name="fruit" />
		苹果
	</label>
</p>
<p>
	<label>
		<input type="radio" value="桔子" name="fruit" />
		桔子
	</label>
</p>
<p>
	<label>
		<input type="radio" value="葡萄" name="fruit" />
		葡萄
	</label>
</p>

<p>你喜欢的是:</p>
<p id="pApple" style="color:red">苹果</p>
<p id="pOrange" style="color:orange">桔子</p>
<p id="pGrape" style="color:purple;">葡萄</p>

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素_字符串

这样,我们在网页上显示苹果、桔子和葡萄三种水果名称,请用户从中选择自己喜欢的一种水果,然后我们在下方根据用户的选择显示对应的一种水果名称,把其余两种水果隐藏起来。

下面我们分别使用纯JavaScript和Vue的 v-if 指令来实现。

1 使用纯JavaScript来实现

radio按钮支持click和change两个事件,我们可以通过响应这两个事件来实现。

1.1 使用click事件

在JavaScript中处理事件,有两种方式,一种是在组件描述代码中使用onclick 指定事件处理器,另一种是使用使用EventTarget.addEventListener() 方法将指定的监听器,详见:Vue学习笔记3:对比纯JavaScript和Vue实现数据更新的实时视图显示_PurpleEndurer@5lcto的技术博客_51CTO博客

这里我们使用在radio 描述代码中使用onclick 指定事件处理器的方式。

1.1.1 修改 radio 描述代码

1.1.1.1 修改苹果 radio的描述代码

<input type="radio" value="苹果" name="fruit" />

改为

		<input type="radio" value="苹果" name="fruit" onclick="showFruit(this.value)" />
1.1.1.2 修改桔子 radio的描述代码

<input type="radio" value="桔子" name="fruit" />

改为

<input type="radio" value="桔子" name="fruit" onclick="showFruit(this.value)" />
1.1.1.3 修改葡萄 radio的描述代码

<input type="radio" value="葡萄" name="fruit" />

改为

<input type="radio" value="葡萄" name="fruit" onclick="showFruit(this.value)" />

我们给三个radio按钮增加了代码:onclick="showFruit(this.value)"

指定发生click事件时交给函数showFruit来处理,并把radio的值(this.value)作为函数showFruit的输入参数传递过去。


1.1.2 增加JavaScript代码<script>...</script>

<script>
	function showFruit(v)
	{
		document.getElementById('pApple').style.display  = (v=='苹果' ? "inherit" : "none");
		document.getElementById('pOrange').style.display = (v=='桔子' ? "inherit" : "none");
		document.getElementById('pGrape').style.display  = (v=='葡萄' ? "inherit" : "none");
	}
</script>

在<script></script>中我们增加了函数showFruit。

在函数showFruit根据输入的参数,即用户所选择的水果名称来进行比较,通过style.display 属性调整三种水果名称元素的显示状态:名称相同就显示,名称不同就隐藏。

完整的代码如下:

<script>
	function showFruit(v)
	{
		document.getElementById('pApple').style.display  = (v=='苹果' ? "inherit" : "none");
		document.getElementById('pOrange').style.display = (v=='桔子' ? "inherit" : "none");
		document.getElementById('pGrape').style.display  = (v=='葡萄' ? "inherit" : "none");
	}
</script>

<p>用JavaScript响应click事件有条件地渲染网页元素</p>
<p style="margin-left:20%; color:purple; font-weight:bold;">
	by PurpleEndurer
</p>
<p>你喜欢哪种水果?</p>
<p>
	<label>
		<input type="radio" value="苹果" name="fruit" onclick="showFruit(this.value)" />
		苹果
	</label>
</p>
<p>
	<label>
		<input type="radio" value="桔子" name="fruit" onclick="showFruit(this.value)" />
		桔子
	</label>
</p>
<p>
	<label>
		<input type="radio" value="葡萄" name="fruit" onclick="showFruit(this.value)" />
		葡萄
	</label>
</p>

<p>你喜欢的是:</p>
<p id="pApple" style="color:red">苹果</p>
<p id="pOrange" style="color:orange">桔子</p>
<p id="pGrape" style="color:purple;">葡萄</p>

代码运行效果如下:

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素_Vue_02

1.1.2 使用change事件

 使用change事件实现和1.1.1使用click事件是类似的,只要做两点修改

1.1.2.1 将 

<p>用JavaScript响应click事件有条件地渲染网页元素</p>

改为

<p>用JavaScript响应change事件有条件地渲染网页元素</p>

1.1.2.2 

radio 描述代码中的 onclick="showFruit(this.value)" 改为 onchange="showFruit(this.value)"。

函数showFruit不用修改。

修改后的代码如下:

<script>
	function showFruit(v)
	{
		document.getElementById('pApple').style.display  = (v=='苹果' ? "inherit" : "none");
		document.getElementById('pOrange').style.display = (v=='桔子' ? "inherit" : "none");
		document.getElementById('pGrape').style.display  = (v=='葡萄' ? "inherit" : "none");
	}
</script>

<p>用JavaScript响应change事件有条件地渲染网页元素</p>
<p style="margin-left:20%; color:purple; font-weight:bold;">
	by PurpleEndurer
</p>
<p>你喜欢哪种水果?</p>
<p>
	<label>
		<input type="radio" value="苹果" name="fruit" onchange="showFruit(this.value)" />
		苹果
	</label>
</p>
<p>
	<label>
		<input type="radio" value="桔子" name="fruit" onchange="showFruit(this.value)" />
		桔子
	</label>
</p>
<p>
	<label>
		<input type="radio" value="葡萄" name="fruit" onchange="showFruit(this.value)" />
		葡萄
	</label>
</p>

<p>你喜欢的是:</p>
<p id="pApple" style="color:red">苹果</p>
<p id="pOrange" style="color:orange">桔子</p>
<p id="pGrape" style="color:purple;">葡萄</p>

代码运行效果如下:

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素_字符串_03

2 使用vue的v-if系列指令来实现

vue 提供了 v-if、v-elseif 和 v-else 指令组合来实现有条件地渲染元素。

同样,我们可以使用click和change事件来实现。

2.1 使用 click事件来实现

我们在 1.1 的代码基础上进行修改。

2.1.1 修改<script>...</script>

2.1.1.1 将 <script> 改为 <script setup>

在Vue3.2 中, 只需要在 script 标签上加上 setup 属性,组件在编译的过程中代码运行的上下文是在 setup() 函数中,无需 return,template 可直接使用。

2.1.1.2 增加语句 import { ref } from 'vue'

声明一个响应式引用 (ref)。

2.1.1.3 增加语句 const yourFruit = ref('苹果');

定义数据成员 yourFruit,初始化值 为'苹果'。

下面会使用 yourFruit 来保存 用户选择的水果名称,并 根据 yourFruit的 值来控制用户选择结果的显示。

2.1.1.4 修改函数showFruit

将函数体从

		document.getElementById('pApple').style.display  = (v=='苹果' ? "inherit" : "none");
		document.getElementById('pOrange').style.display = (v=='桔子' ? "inherit" : "none");
		document.getElementById('pGrape').style.display  = (v=='葡萄' ? "inherit" : "none");

改为

	yourFruit.value = v;

yourFruit 是字符串类型,我们使用value属性来保存用户选择的水果名称。

修改后的  <script>...</script> 代码如下:

<script setup>

import { ref } from 'vue'

const yourFruit = ref('苹果');

//yourFruit.value = '苹果'

function showFruit(v)
{
	//alert(v);
	//alert(yourFruit.value)
	yourFruit.value = v;
}
</script>

2.1.2 修改网页描述代码

2.1.2.1 将 <p>用JavaScript响应click事件有条件地渲染网页元素</p> 改为

<p>用Vue 的v-if指令响应click事件有条件地渲染网页元素</p>

2.1.2.2 修改 radio描述代码


2.1.2.2.1 修改苹果 radio的描述代码

<input type="radio" value="苹果" checked name="fruit" onclick="showFruit(this.value)" />

改为

<input type="radio" value="苹果" checked name="fruit" checked @click="showFruit('苹果')" />
2.1.2.2.2 修改桔子 radio的描述代码

<input type="radio" value="桔子" name="fruit" onclick="showFruit(this.value)" />

改为

<input type="radio" value="桔子" name="fruit" @click="showFruit('桔子')" />
2.1.2.2.3 修改葡萄 radio的描述代码

<input type="radio" value="葡萄" name="fruit" onclick="showFruit(this.value)" />

改为

<input type="radio" value="葡萄" name="fruit" @click="showFruit('葡萄')" />

以上修改归纳起来有三个方面:

1 给苹果radio增加了一个属性checked,表示该选项处于选中状态

这是因为数据成员 yourFruit的初始化值 为'苹果'。

不增这个选项,页面显示会是这样的:

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素_Vue_04

用户还没有选择自己喜欢哪个水果,下面已经显示选择的结果是苹果了。

如果用户喜欢的不是苹果,那就尴尬了。

2 将 onclick 改为 @click

3.将函数showFruit的传入参数 从this.value改为对应的水果名称,如'苹果'

如果函数showFruit的传入参数 继续使用 this.value,那么在函数showFruit(v)内部进行处理的时候,用alert(v)来显示v的值时就会发现 其值undefined(未定义)。

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素_字符串_05

Vue学习笔记5:用Vue的事件监听 实现数据更新的实时视图显示_PurpleEndurer@5lcto的技术博客_51CTO博客 中,我们对文本框使用this.value就没有出现这个问题。

2.1.2.3 修改代表用户选择水果的 <p></p>代码
2.1.2.3.1 修改苹果的代码

<p id="pApple" value="苹果" style="color:red">苹果</p>

改为

<p id="pApple" style="color:red" v-if="yourFruit.valueOf()=='苹果'">苹果</p>

这里我们增加了vue 的条件渲染指令v-if="yourFruit.valueOf()=='苹果'" 

如果yourFruit.valueOf()的值是‘苹果’,那么表达式yourFruit.valueOf()=='苹果' 的结果为true,这个<p>...</p>就会显示出来,说明用户选择的是苹果。

如果yourFruit.valueOf()的值不是‘苹果’,那么表达式yourFruit.valueOf()=='苹果' 的结果为false,这个<p>...</p>就不会显示出来,说明用户选择的不是苹果。

由于yourFruit是字符串类型,所以我们用它的valueOf()方法来获取其值。

2.1.2.3.2 修改桔子的代码

<p id="pOrange" style="color:orange">桔子</p>

改为

<p id="pOrange" style="color:orange" v-else-if="yourFruit.valueOf()=='桔子'">桔子</p>

这里我们增加了vue 的条件渲染指令v-else-if="yourFruit.valueOf()=='桔子'" 

它和上面的vue 的条件渲染指令v-if="yourFruit.valueOf()=='苹果'" 是一起联动使用的。

如果上面的vue 条件渲染指令v-if="yourFruit.valueOf()=='苹果'" 结果是true,就不会再执行 v-else-if="yourFruit.valueOf()=='桔子'" 及后续的v-else指令了。

如果上面vue 的条件渲染指令v-if="yourFruit.valueOf()=='苹果'" 结果是false,那么就会执行v-else-if="yourFruit.valueOf()=='桔子'" 。

如果yourFruit.valueOf()的值是‘桔子’,那么表达式yourFruit.valueOf()=='桔子' 的结果为true,这个<p>...</p>就会显示出来,说明用户选择的是桔子。

如果yourFruit.valueOf()的值不是‘桔子’,那么表达式yourFruit.valueOf()=='苹果' 的结果为false,这个<p>...</p>就不会显示出来,说明用户选择的不是桔子。

2.1.2.3.3 修改葡萄的代码

<p id="pGrape" style="color:purple;">葡萄</p>

改为

<p id="pGrape" style="color:purple;" v-else>葡萄</p>

这里我们增加了vue 的条件渲染指令v-else

它和上面的vue 的条件渲染指令v-if="yourFruit.valueOf()=='苹果'" 及 令v-else-if="yourFruit.valueOf()=='桔子'" 是一起联动使用的。

如果yourFruit.valueOf()的值是‘葡萄’,那么v-if="yourFruit.valueOf()=='苹果'" 及 令v-else-if="yourFruit.valueOf()=='桔子'"  的结果均为false,这两个<p>...</p>都不会显示出来,排除了苹果和桔子,用户选择必定是葡萄,我们也就不需要使用表达式再来作判断了。

2.1.2.4 增加<template></template>

以上所有修改汇总后的最终代码如下:

OK

<script setup>

import { ref } from 'vue'

const yourFruit = ref('苹果');

function showFruit(v)
{
	//alert(v);
	//alert(yourFruit.value)
	yourFruit.value = v;
}

</script>

<template>
  
<p>用Vue 的v-if指令响应click事件有条件地渲染网页元素</p>
<p style="margin-left:20%; color:purple; font-weight:bold;">
	by PurpleEndurer
</p>

<p>你喜欢哪种水果?</p>
<p>
	<label>
        <input type="radio" value="苹果" checked name="fruit" @click="showFruit('苹果')" />
        苹果
	</label>
</p>
<p>
	<label>
          <input type="radio" value="桔子" name="fruit" @click="showFruit('桔子')" />
          桔子
	</label>
</p>
<p>
	<label>
		<input type="radio" value="葡萄" name="fruit" @click="showFruit('葡萄')" />
        葡萄
	</label>
</p>

<p>你喜欢的是:</p>
<p id="pApple" style="color:red" v-if="yourFruit.valueOf()=='苹果'">苹果</p>
<p id="pOrange" style="color:orange" v-else-if="yourFruit.valueOf()=='桔子'">桔子</p>
<p id="pGrape" style="color:purple;" v-else>葡萄</p>

</template>

代码运行效果如下:

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素_字符串_06

2.2 使用change事件来实现

使用change事件来实现,与使用click事件是相似的。

我们在 2.1的代码基础上进行修改。

需要修改的有两个地方:

2.2.1 将<p>用Vue 的v-if指令响应click事件有条件地渲染网页元素</p> 改为 <p>用Vue 的v-if指令响应change事件有条件地渲染网页元素</p>

2.2.2 将 3个radio按钮描述代码中的 @click  改为 @change

即将

<input type="radio" value="苹果" checked name="fruit" @change="showFruit('苹果')" />
<input type="radio" value="桔子" name="fruit" @change="showFruit('桔子')" />
<input type="radio" value="葡萄" name="fruit" @change="showFruit('葡萄')" />

相应地改为

<input type="radio" value="苹果" checked name="fruit" @change="showFruit('苹果')" />
<input type="radio" value="桔子" name="fruit" @change="showFruit('桔子')" />
<input type="radio" value="葡萄" name="fruit" @change="showFruit('葡萄')" />

修改后的最终代码为:

OK

<script setup>

import { ref } from 'vue'

const yourFruit = ref('苹果');

function showFruit(v)
{
	//alert(v);
	//alert(yourFruit.value)
	yourFruit.value = v;
}

</script>

<template>
  
<p>用Vue 的v-if指令响应change事件有条件地渲染网页元素</p>
<p style="margin-left:20%; color:purple; font-weight:bold;">
	by PurpleEndurer
</p>

<p>你喜欢哪种水果?</p>
<p>
	<label>
        <input type="radio" value="苹果" checked name="fruit" @change="showFruit('苹果')" />
        苹果
	</label>
</p>
<p>
	<label>
          <input type="radio" value="桔子" name="fruit" @change="showFruit('桔子')" />
          桔子
	</label>
</p>
<p>
	<label>
		<input type="radio" value="葡萄" name="fruit" @change="showFruit('葡萄')" />
        葡萄
	</label>
</p>

<p>你喜欢的是:</p>
<p id="pApple" style="color:red" v-if="yourFruit.valueOf()=='苹果'">苹果</p>
<p id="pOrange" style="color:orange" v-else-if="yourFruit.valueOf()=='桔子'">桔子</p>
<p id="pGrape" style="color:purple;" v-else>葡萄</p>

</template>

代码运行的效果如下:

Vue学习笔记6:分别使用纯JavaScript和Vue的v-if 指令来有条件地渲染网页元素_字符串_07

标签:Vue,网页,valueOf,JavaScript,桔子,showFruit,苹果,yourFruit,2.1
From: https://blog.51cto.com/endurer/12075038

相关文章

  • springboot+vue在线动漫信息平台【开题+程序+论文】
    系统程序文件列表开题报告内容研究背景随着互联网的飞速发展,动漫文化在全球范围内迅速普及,成为年轻人娱乐与社交的重要载体。传统动漫传播方式受限于时间与空间,已难以满足日益增长的动漫爱好者需求。在线动漫信息平台作为连接创作者与观众的桥梁,不仅能够提供丰富多样的动漫......
  • springboot+vue自行车租赁管理系统【开题+程序+论文】
    系统程序文件列表开题报告内容研究背景随着城市化进程的加速和环保意识的提升,自行车作为绿色出行方式,其租赁服务在近年来得到了迅猛发展。传统的自行车租赁方式存在管理效率低下、信息不透明、用户体验不佳等问题,已难以满足现代都市人便捷、高效、环保的出行需求。因此,开发......
  • springboot+vue幼儿园管理系统【开题+程序+论文】
    系统程序文件列表开题报告内容研究背景随着教育信息化的不断深入,幼儿园作为儿童成长启蒙的重要阶段,其管理模式的现代化与智能化已成为必然趋势。传统的幼儿园管理方式往往依赖于纸质记录和人工操作,不仅效率低下,还容易出错,难以满足当前家长对幼儿教育透明化、个性化、高质量......
  • 基于Node.js+vue基于springboot的电商后台管理系统(开题+程序+论文) 计算机毕业设计
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容研究背景随着互联网技术的飞速发展和电子商务行业的蓬勃兴起,电商企业面临着前所未有的机遇与挑战。为了提升运营效率、优化客户体验并增强市场竞争力,电商企业亟需构......
  • 基于Node.js+vue基于SpringBoot的小区入住管理系统(开题+程序+论文) 计算机毕业设计
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容研究背景随着城市化进程的加速,住宅小区作为城市居民生活的重要载体,其管理效率与服务质量直接关系到居民的生活品质与幸福感。传统的小区管理方式往往依赖于人工记录......
  • 基于Node.js+vue基于SpringBoot框架的球鞋洗护平台(开题+程序+论文) 计算机毕业设计
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容研究背景随着运动文化的兴起和消费者对生活品质要求的提升,球鞋已不仅仅是一种运动装备,更成为了时尚潮流的象征。然而,高端球鞋的清洁与保养却成为了一个难题,传统的手......
  • 了解 Javascript 中的 POST 请求
    functionnewPlayer(newForm){fetch("http://localhost:3000/Players",{method:"POST",headers:{'Content-Type':'application/json'},body:JSON.stringify(newForm)}).then(resp=&g......