[笔记]vue从入门到入坟《三》条件与循环、处理用户输入、组件化应用构建

简介: [笔记]vue从入门到入坟《三》条件与循环、处理用户输入、组件化应用构建

一、条件与循环

1.1 条件语句

1.1.1 v-if、v-else、v-else-if

<h2>v-if</h2>
    <h1 v-if="awesome">Vue is awesome!</h1>
    <h1 v-else>Oh no 😢</h1>
    <h2>template</h2>
    <h2>v-else</h2>
    <div v-if="Math.random() > 0.5">
        Now you see me
    </div>
    <div v-else>
        Now you don't
    </div>
    <h2>v-else-if</h2>
    <div v-if="type === 'A'">
        A
    </div>
    <div v-else-if="type === 'B'">
        B
    </div>
    <div v-else-if="type === 'C'">
        C
    </div>
    <div v-else>
        Not A/B/C
    </div>
</div>
<script type="text/javascript" src="js/vue2.6.js"></script>
<script type="text/javascript">
    new Vue({
        el:'#app',
        data:{
            awesome:true,
            ok:true,
            type:'A'
        }
    })
</script>

1.1.2 v-show

1.2 模板语法

1.2.1 template v-if

<template v-if="ok">
    <h1>Title</h1>
    <p>Paragraph 1</p>
    <p>Paragraph 2</p>
</template>
<script type="text/javascript">
 new Vue({
     el:'#app',
     data:{
         ok:true
     }
})
</script>

1.2.1 Key管理可复用的元素

key:key的name相同时表示是为同一属性赋值,切换时保留值;不同则切换时不保留。

<h2> key 管理可复用的元素</h2>
<template v-if="loginType === 'username'">
        <label>Username</label>
        <input placeholder="Enter your username" key="username-input">
</template>
<template v-else>
        <label>Email</label>
        <input placeholder="Enter your email address" key="email-input">
</template>
<script type="text/javascript">
    new Vue({
        el:'#app',
        data:{
            loginType:'username'
        },
        methods:{
            toggle(){
                this.loginType =this.loginType=='username'?'email':'username';
            }
        }
    });
</script>

运行效果

key不同时:

key相同时即key=“username-input”

2.循环语句

2.1 v-for

<h2>v-for</h2>
    <div id="app-4">
        <ol>
            <li v-for="todo in todos">
                {{ todo.text }}
            </li>
        </ol>
</div>
<script type="text/javascript">
    new Vue({
        el:'#app',
        data:{
            awesome:true,
            ok:true,
            type:'A',
            todos:[
                {
                    text:'学习javascript'
                },
                {
                     text:'学习vue'
                },
                {
                    text:'学习c++'
                }
            ]
        }
    })
</script>

二、处理用户输入

2.1 {{message}}

<h2>用户输入</h2>
<div id="app-5">
    <p>{{ message }}</p>
    <button v-on:click="reverseMessage">反转消息</button>
</div>
<script type="text/javascript">
    new Vue({
        el:'#app-5',
        data:{
            message:'hello vue.js!'
        },
        methods:{
            reverseMessage(){
                this.message = this.message.split('').reverse().join(' ');
            },
        }
    });
</script>

2.2 v-model

数据和dom 双向绑定

<h2>v-model</h2>
<div>
        <p>{{ message }}</p>
        <input v-model="message" />
</div>

三、组件化应用构建


# 问题记录 ## 问题 1:new vue 是否全局只能有一个? ## 问题 2:el语句的含义是? ## 问题3:v-show和v-if使用区别?

v-show:经常需要显示Dom时,减少底层渲染。

v-if:非必须显示内容,显示次数较少时。

未完待续…

相关文章
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
2月前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发
|
2月前
|
JavaScript 搜索推荐 前端开发
Vue SSR 预渲染的广泛应用场景及其优势
【10月更文挑战第23天】Vue SSR 预渲染技术在众多领域都有着广泛的应用价值,可以显著提升网站的性能、用户体验和搜索引擎优化效果。随着技术的不断发展和完善,其应用场景还将不断拓展和深化
54 2
|
2月前
|
JavaScript 前端开发 API
Vue.js 3:深入探索组合式API的实践与应用
Vue.js 3:深入探索组合式API的实践与应用
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
缓存 JavaScript 数据管理
优化 Vue 应用中的性能
【10月更文挑战第22天】优化 Vue 应用性能需要综合考虑多个方面,从数据管理、组件化、虚拟 DOM 操作、网络请求、代码结构等多方面入手,不断进行优化和改进,以提供更流畅的用户体验。同时,要根据具体的应用场景和需求,选择合适的优化策略,确保性能优化的效果和可行性。
|
3天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
35 1
|
14天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
45 1
vue学习第一章