IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 条件渲染 |列表渲染 |key原理 -> 正文阅读

[JavaScript知识库]条件渲染 |列表渲染 |key原理

一.条件渲染

1.v-if

写法:

(1)v-if=“表达式”

(2)v-else-if=“表达式”

(3)v-else=“表达式”

适用于:切换频率较低的场景

特点:不展示DOM元素直接被移除

注意:v-if可以和:v-else-if\v-else一起用,但邀请结构不能被打断

2.v-show

写法:v-show=“表达式”

适用于:切换频率较高的场景

特点:不展示的DOM元素未被移除,仅仅是使用样式隐藏掉

3.备注:使用v-if时,元素可能无法获取到,而使用v-show一定可以获取到

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8"/>
		<title>初识vue</title>
		<script type="text/javascript" src="../js/vue.js">
			alert("这是我的第一行JS代码")
			document.write("看我出不出来")
		</script>
	</head>
	<body>
        <!-- 容器 -->
        <div id="root">
            <h2>{{n}}</h2>
            <button @click="n++">点我加1</button>
            <!-- 使用v-show做条件渲染 -->
            <!-- <h2 v-show="false">hello{{name}}</h2>
            <h2 v-show="1 ===1">hello{{name}}</h2> -->
            <!-- 使用v-if做条件渲染 -->
            <!-- <h2 v-if="false">hello{{name}}</h2>
            <h2 v-if="1 ===1">hello{{name}}</h2> -->
            <!-- v-else和v-else-if -->
            <!-- <div v-if="n===1">A</div>
            <div v-else-if="n===2">B</div>
            <div v-else-if="n===3">C</div>
            <div v-else>哈哈</div> -->
            <template v-if="n===1">
                <h2>你好</h2>
                <h2>哈哈</h2>
                <h2>嗯嗯</h2>
            </template>
        </div>
        
		<script type="text/javascript" >
        Vue.config.productionTip = false
        const vm = new Vue({
            el:'#root',
            data:{
                name:'atguigu',
                a:false,
                n:0
            },
        })
        console.log(vm)
       
        </script>
	</body>
</html>

二.列表渲染

v-for指令

1。用于展示列表数据

2.语法:v-for="(item,index) in xxx" :key="yyy"

3.可遍历:数组、对象、字符串(很少)、指定次数(很少)

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8"/>
		<title>姓名案例</title>
		<script type="text/javascript" src="../js/vue.js">
		</script>
	</head>
	<body>
        <!-- 容器 -->
        <div id="root">
            <!-- 遍历数组(用的多) -->
            <ul>
                <!-- <li v-for="p in persons" :key="p.id">
                    {{p.name}}-{{p.age}}
                </li> -->
                <li v-for="(p,index) in persons" :key="index">
                    {{p.name}}-{{p.age}}
                </li>
            </ul>
            <!-- 遍历对象 -->
            <ul>
                <li v-for="(val,key) in car" :key="key">
                    {{key}}-{{val}}
                </li>
            </ul>
            <!-- 遍历字符串(用得少) -->
            <ul>
                <li v-for="(char,index) in str" :key="index">
                    {{char}}-{{index}}
                </li>
            </ul>
            <!-- 遍历指定次数(用得少) -->
            <ul>
                <li v-for="(number,index) in 5" :key="index">
                    {{index}}-{{number}}
                </li>
            </ul>
        </div>
        
		<script type="text/javascript" >
        Vue.config.productionTip = false
        new Vue({
            el:'#root',
            data:{
                persons:[
                {id:'001',name:'张三',age:'18'},
                {id:'002',name:'李四',age:'19'},
                {id:'003',name:'王五',age:'20'}
                ],
                car:{
                    name:"aodiA8",
                    price:"70wan",
                    color:"black"
                },
                str:'hello'
            }
        })
        </script>
	</body>
</html>

in也可以改为of

最后写上小括号

三.Key原理

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8"/>
		<title>姓名案例</title>
		<script type="text/javascript" src="../js/vue.js">
		</script>
	</head>
	<body>
        <!-- 容器 -->
        <div id="root">
            <!-- 遍历数组(用的多) -->
            <button @click="add">增加老刘</button>
            <ul>
                <li v-for="(p,index) in persons" :key="index">
                    {{p.name}}-{{p.age}}
                    <input type="text">
                </li>
            </ul>
           
        </div>
        
		<script type="text/javascript" >
        Vue.config.productionTip = false
        new Vue({
            el:'#root',
            data:{
                persons:[
                {id:'001',name:'张三',age:'18'},
                {id:'002',name:'李四',age:'19'},
                {id:'003',name:'王五',age:'20'}
                ],
                car:{
                    name:"aodiA8",
                    price:"70wan",
                    color:"black"
                },
                str:'hello'
            },
            methods:{
                add(){
                    const p = {id:'004',name:'老刘',age:'21'}
                    this.persons.unshift(p)
                }
            }
        })
        </script>
	</body>
</html>

当key作为列表渲染,以上代码会有问题。需要改为id作为key

?

react和Vue中key有什么作用?(key的原理)

1.虚拟

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-15 22:23:40  更:2022-03-15 22:25:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 15:53:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码