[笔记]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:非必须显示内容,显示次数较少时。

未完待续…

相关文章
|
23小时前
|
JavaScript 网络架构
|
22小时前
|
人工智能 JavaScript 索引
Duplicate keys detected: This may cause an update error.【Vue遍历渲染报错的解决】
这篇文章讨论了在Vue中进行列表渲染时遇到的“Duplicate keys detected”错误。这个错误通常发生在使用 `v-for` 指令渲染列表时,如果没有为每个循环项指定一个唯一的 `key` 属性,或者指定的 `key` 属性值重复了。文章提供了导致错误的原始代码示例,并给出了修正后的代码,通过在 `key` 绑定中加入索引确保 `key` 的唯一性。此外,文章还解释了为什么需要唯一 `key` 以及如何解决这个问题。
Duplicate keys detected: This may cause an update error.【Vue遍历渲染报错的解决】
|
1天前
|
缓存 移动开发 JavaScript
查漏补缺方为上策!!两万六字总结vue的基本使用和高级特性,周边插件vuex和vue-router任你挑选
该文章全面总结了Vue.js的基本使用方法与高级特性,并介绍了Vue周边的重要插件Vuex和Vue-Router的使用技巧。
查漏补缺方为上策!!两万六字总结vue的基本使用和高级特性,周边插件vuex和vue-router任你挑选
|
1天前
|
开发框架 JavaScript 前端开发
手把手教你剖析vue响应式原理,监听数据不再迷茫
该文章深入剖析了Vue.js的响应式原理,特别是如何利用`Object.defineProperty()`来实现数据变化的监听,并探讨了其在异步接口数据处理中的应用。
|
JavaScript 测试技术 容器
Vue2+VueRouter2+webpack 构建项目
1). 安装Node环境和npm包管理工具 检测版本 node -v npm -v 图1.png 2). 安装vue-cli(vue脚手架) npm install -g vue-cli --registry=https://registry.
1037 0
|
2天前
|
JavaScript
Vue使用element中table组件实现单选一行
如何在Vue中使用Element UI的table组件实现单选一行的功能。
16 5
Vue使用element中table组件实现单选一行
|
2天前
|
JavaScript
Vue实现按钮级别权限
文章介绍了在Vue中实现按钮级别权限的两种方法:使用自定义Vue指令和使用v-if指令配合自定义方法。
12 4
Vue实现按钮级别权限
|
1天前
|
缓存 JavaScript 前端开发
vue-day02计算属性,v-bind,v-if,v-for
文章介绍了Vue.js中的计算属性、class与style的绑定、条件渲染和列表渲染的使用。通过示例代码展示了如何使用计算属性简化模板逻辑、如何通过v-bind动态绑定class和style、如何使用v-if进行条件渲染以及如何使用v-for进行列表渲染。这些特性使得Vue.js在构建动态用户界面时更加灵活和强大。
vue-day02计算属性,v-bind,v-if,v-for
|
1天前
|
JavaScript
vue项目中使用vue-router进行路由配置及嵌套多级路由
该文章详细说明了如何在Vue项目中配置和使用vue-router进行单页面应用的路由管理,包括设置嵌套路由和实现多级路由导航的示例。
vue项目中使用vue-router进行路由配置及嵌套多级路由
|
2天前
|
JavaScript
Vue+element_Table树形数据与懒加载报错Error in render: “RangeError: Maximum call stack size exceeded“
本文讨论了在使用Vue和Element UI实现树形数据和懒加载时遇到的“Maximum call stack size exceeded”错误,指出问题的原因通常是因为数据中的唯一标识符`id`不唯一,导致递归渲染造成调用栈溢出。
10 1
Vue+element_Table树形数据与懒加载报错Error in render: “RangeError: Maximum call stack size exceeded“