02-Vue基础之条件渲染和列表渲染

文章目录

    • 01.条件渲染
      • 1.1.v-if 使用场景
      • 1.2.v-show使用场景
    • 02.列表渲染
      • 2.1.v-for的基本使用
      • 2.2.v-for遍历时key的选择问题

01.条件渲染

Vue中的条件渲染指的是,我们可以在视图中选择性的显示一些内容,条件渲染的可以使用以下两种指令来实现:

  • v-if
    • 特点:不展示的DOM元素直接被移除,即动态的向DOM树内添加或者删除DOM元素,注意,不是隐藏是销毁删除
    • 适用于:切换频率较低的场景。
    • 注意:v-if可以和v-else-ifv-else一起使用,但要求结构不能被打断
  • v-show
    • 特点:不展示的DOM元素未被移除,仅仅是使用样式隐藏掉 ,本质就是控制标签的display属性,来实现对标签的隐藏显示,并且只编译一次。
    • 适用于:切换频率较高的场景。
    • 写法:v-show="表达式"

注意:使用v-if的时,元素可能无法获取到,而使用v-show一定可以获取到。

1.1.v-if 使用场景

DOCTYPE html>
<html>
	<head>
		<title>条件渲染 v-iftitle>
		<script type="text/javascript" src="../js/vue.js">script>
	head>
	<body>
		<div id="root">
            <h2>当前的n值是:{{n}}h2>
			<button @click="n++">点我n+1button>

			
			<h2 v-if="true">欢迎你 {{name}}h2> 
			<h2 v-if="1 === 1">欢迎你 {{name}}h2>

			
            
			<div v-if="n === 1">Angulardiv>
			<div v-else-if="n === 2">Reactdiv>
			<div v-else-if="n === 3">Vuediv>
			<div v-else>哈哈div>

			
			<template v-if="true">
				<h2>你好h2>
				<h2>AISMALLh2>
				<h2>Javah2>
			template>
		div>
	body>
	<script type="text/javascript">
		const vm = new Vue({
			el:'#root',
			data:{
				name:'AISMALL',
				n:0
			}
		})
	script>
html>

1.2.v-show使用场景

DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8" />
		<title>条件渲染 v-showtitle>
		<script type="text/javascript" src="../js/vue.js">script>
	head>
	<body>
		<div id="root">
			<h2>当前的n值是:{{n}}h2>
			<button @click="n++">点我n+1button>
			
			<h2 v-show="true">欢迎你 {{name}}h2> 
			<h2 v-show="n === 1">欢迎你 {{name}}h2>
		div>
	body>
	<script type="text/javascript">
		const vm = new Vue({
			el:'#root',
			data:{
				name:'AISMALL',
				n:0
			}
		})
	script>
html>

02.列表渲染

Vue中的条件渲染指的是,获取列表中的各种数据,并将它展示出来,列表渲染一般使用v-for指令来实现,根据遍历数据(数组对象字符串指定次数)的不同可进行分类:

v-for遍历数组

  • 方式一:

  • {{item}}
  • 语法解析:

    • item:为标签内要填充的内容
    • in:关键字
    • list:待遍历的数组
  • 方式二:

  • {{item}} + '---' +{{index}}
  • 语法解析:

    • item:为标签内要填充的内容
    • index:数组的索引
    • in:关键字
    • list:待遍历的数组
  • 注意:key的作用是帮助Vue区分不同的元素,从而提高性能

v-for遍历对象

  • 方式一:

  • 语法解析:

    • value:对象的value
    • key:代表对象的键
  • 方式二:

  • 语法解析:

    • value:对象的value
    • key:代表对象的键
    • index:代表索引
  • 注意:不推荐同时使用v-if和v-for,当v-if与v-for一起使用时,v-for具有比v-if更高的优先级。

举个例子:

2.1.v-for的基本使用

  • 使用v-for指令遍历数组对象字符串(用的很少)指定次数(用的很少)
DOCTYPE html>
<html>
	<head>
		<title>列表渲染title>
		<script type="text/javascript" src="../js/vue.js">script>
	head>
	<body>
		<div id="root">
			
			<h2>人员列表(遍历数组)h2>
			<ul>
				<li v-for="(p,index) of persons" :key="index">
					{{p.name}}-{{p.age}}
				li>
			ul>

			
			<h2>汽车信息(遍历对象)h2>
			<ul>
				<li v-for="(value,k) of car" :key="k">
					{{k}}-{{value}}
				li>
			ul>

			
			<h2>测试遍历字符串(用得少)h2>
			<ul>
				<li v-for="(char,index) of str" :key="index">
					{{char}}-{{index}}
				li>
			ul>
			
			
			<h2>测试遍历指定次数(用得少)h2>
			<ul>
				<li v-for="(number,index) of 5" :key="index">
					{{index}}-{{number}}
				li>
			ul>
		div>

		<script type="text/javascript">
			new Vue({
				el:'#root',
				data:{
					persons:[
						{id:'001',name:'张三',age:18},
						{id:'002',name:'李四',age:19},
						{id:'003',name:'王五',age:20}
					],
					car:{
						name:'奥迪A8',
						price:'70万',
						color:'黑色'
					},
					str:'hello'
				}
			})
		script>
html>

2.2.v-for遍历时key的选择问题

问题1:react、vue中的key有什么作用?(key的内部原理)

  • key是虚拟DOM对象的标识,当数据发生变化时,Vue会根据新数据生成新的虚拟DOM,随后Vue进行新虚拟DOM旧虚拟DOM的差异比较,比较规则如下:

    1、旧虚拟DOM中找到了与新虚拟DOM相同的key:
    - 若虚拟DOM中内容没变, 直接使用之前的真实DOM!
    - 若虚拟DOM中内容变了, 则生成新的真实DOM,随后替换掉页面中之前的真实DOM。
    
    2、旧虚拟DOM中未找到与新虚拟DOM相同的key
    - 创建新的真实DOM,随后渲染到到页面。
    
    DOCTYPE html>
    <html>
    	<head>
    		<title>key的原理title>
    		<script type="text/javascript" src="../js/vue.js">script>
    	head>
    	<body>
    		<div id="root">
    			
    			<h2>人员列表(遍历数组)h2>
    			<button @click.once="add">添加一个老刘button>
    			<ul>
    				<li v-for="(p,index) of persons" :key="index">
    					{{p.name}}-{{p.age}}-{{index}}
    				li>
    			ul>
    		div>
    		<script type="text/javascript">
    			new Vue({
    				el:'#root',
    				data:{
    					persons:[
    						{id:'001',name:'张三',age:18},
    						{id:'002',name:'李四',age:19},
    						{id:'003',name:'王五',age:20}
    					]
    				},
    				methods: {
    					add(){
    						const p = {id:'004',name:'老刘',age:40}
    						this.persons.unshift(p)
    					}
    				},
    			})
    		script>
    html>
    

问题2:用index作为key可能会引发的问题?

  • 1、 若对数据进行逆序添加逆序删除等破坏顺序操作,会产生没有必要的真实DOM更新(界面没问题),效率低。

  • 2、如果结构中还包含输入类的DOM,会产生错误DOM更新 ( 界面有问题)。

    DOCTYPE html>
    <html>
    	<head>
    		<title>key的原理title>
    		<script type="text/javascript" src="../js/vue.js">script>
    	head>
    	<body>
    		<div id="root">
    			
    			 <h2>使用默认的index作为keyh2>
    			<h2>人员列表(遍历数组):先在输入框中输入值,然后再点击添加按钮h2>
    			<button @click.once="add">添加一个老刘button>
    			<ul>
    				<li v-for="(p,index) of persons" :key="index">
    					{{p.name}}-{{p.age}}-{{index}}
                        <input type="text">
    				li>
    			ul>
    		div>
    		<script type="text/javascript">
    			new Vue({
    				el:'#root',
    				data:{
    					persons:[
    						{id:'001',name:'张三',age:18},
    						{id:'002',name:'李四',age:19},
    						{id:'003',name:'王五',age:20}
    					]
    				},
    				methods: {
    					add(){
    						const p = {id:'004',name:'老刘',age:40}
    						this.persons.unshift(p)
    					}
    				},
    			})
    		script>
    html>
    

问题3: 开发中如何选择key?

  • 1、最好使用每条数据的唯一标识作为key, 比如id、手机号、身份证号、学号等唯一值。

  • 2、如果不存在对数据的逆序添加、逆序删除等破坏顺序操作,仅用于渲染列表用于展示,使用index作为key是没有问题的。

    DOCTYPE html>
    <html>
    	<head>
    		<title>key的原理title>
    		<script type="text/javascript" src="../js/vue.js">script>
    	head>
    	<body>
    		<div id="root">
    			
                <h2>唯一标识作为key:人员IDh2>
    			<h2>人员列表(遍历数组):先在输入框中输入值,然后再点击添加按钮h2>
    			<button @click.once="add">添加一个老刘button>
    			<ul>
    				<li v-for="(p,index) of persons" :key="p.id">
    					{{p.name}}-{{p.age}}-{{index}}
                        <input type="text">
    				li>
    			ul>
    		div>
    		<script type="text/javascript">
    			new Vue({
    				el:'#root',
    				data:{
    					persons:[
    						{id:'001',name:'张三',age:18},
    						{id:'002',name:'李四',age:19},
    						{id:'003',name:'王五',age:20}
    					]
    				},
    				methods: {
    					add(){
    						const p = {id:'004',name:'老刘',age:40}
    						this.persons.unshift(p)
    					}
    				},
    			})
    		script>
    html>
    

你可能感兴趣的:(前端相关,vue.js,javascript,前端)