vue基础学习笔记

news2024/11/24 8:05:36

1.v-text
设置标签的文本值,将标签内的内容完全替换为v-text绑定的值。
如果想要保留标签内的值,可以采用差值表达式的方式(<h2>text{{message}}</h2>
内部值支持拼接

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

    <div id="app">
        <h2>{{message}}</h2>
        <h2 v-text="message">{{message}}</h2>
        <!-- 测试全覆盖 -->
        <h2 v-text="message">Hi!</h2>
        <!-- 差值表达式 -->
        <h2>Hi!{{message}}</h2>
        <!-- 这样是不行的 -->
        <h2 v-text="message">Hi!{{message}}</h2>
        <!-- 测试拼接 -->
        <h2 v-text="message+'123'">{{message}}</h2>
        <h2>{{message+'456'}}</h2>

    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
        return {
            message: 'Hello!'
        }
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述
2.v-html
设置标签的innerHTML。
如果内容是文本,与v-text功能一致。如果内容是html,则会解析为标签。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

    <div id="app">
        <p v-html="href"></p>
        <!-- 测试文本 -->
        <p v-html="message"></p>
        <!-- 测试v-text -->
        <p v-text="href">{{href}}</p>
        <!-- 测试优先级 -->
        <p v-html="href" v-text="href">{{href}}</p>

    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
        return {
            message:"hello!",
            href:"<a href='https://www.baidu.com'>baidu</a>",
        }
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述
3.v-on
为元素绑定事件。事件绑定的方法写在methods中。v-on可以简写成@。而在方法中想要拿到data中数据,可以使用this关键字。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

    <div id="app">
        <!-- <input type="button" value="事件" v-on:click="方法"> -->
        <input type="button" value="1" v-on:click="doit">
        <input type="button" value="2" v-on:dblclick="doit">
        <input type="button" value="3" v-on:monseenter="doit">
        <input type="button" value="4" @click="doit">

        <h2 @click="changefood">{{food}}</h2>
    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
            return {
                food:"食物",
            }
        },
        methods:{
            doit:function(){
                alert("123456");

            },
            changefood:function(){
                //使用this获取data中的food数据
                this.food += "好吃";
                console.log(this.food)
            },
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述
4.v-show
根据后面布尔表达式的真假实现元素的隐藏。true为显示,false为隐藏。原理是修改元素的display,实现显示隐藏。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

    <div id="app">
        <img src="./bg.jpg" v-show="false">
        <img src="./bg.jpg" v-show="age>18">
        <img src="./cover.png" v-show="true">
        <img src="./cover.png" v-show="age<18">
    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
            return {
                age:17
            }
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述
5.v-if
根据表达式的真假,切换元素的显示和隐藏(操纵dom元素)。
相较于v-show,v-if操纵的是dom树,表达式的值为true,元素存在于dom树中,为false,从dom树中移除;而v-show操纵的是display。
频繁操作时选用v-show,反之采用v-if。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

    <div id="app">
        <input type="button" value="切换显示" @click="change">
        <p v-if="isshow">v-if hello!</p>
        <p v-show="isshow">v-show hello!</p>
    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
            return {
                isshow:false
            }
        },
        methods:{
            change:function(){
                this.isshow=!this.isshow
            }
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述
在这里插入图片描述
6.v-bind
为元素绑定属性。可以缩写为:。
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
    <style>
        .active{
            border: 1px solid red;
        }
    </style>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>

    <div id="app">
        <img src="./cover.png">
        <br>
        <img :src="picurl" v-bind:title="imgtitle" v-bind:class="{active:isshow}" @click="change">
    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
            return {
                picurl:"./cover.png",
                imgtitle:"图片",
                isshow:false
            }
        },
        methods:{
            change:function(){
                this.isshow=!this.isshow
            }
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述
7.v-for
根据数据生成列表结构。经常与数组结合使用。语法为( item,index ) in 数据。数组长度的更新会同步到页面上,是响应式的。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
    <div id="app">
        <li v-for="(item,index) in something">
            <div class="view">
                <span class="index">{{index+1}}.</span>
                <label>{{item}}</label>
                <button class="destory" @click="remove(index)">x</button>
                <button class="add" @click="add">o</button>
            </div>
        </li>
    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
            return{
                something:["1",'2','3','4','5']
            }
        },
        methods:{
            add:function(){
                this.something.push('666');
            },
            remove:function(index){
                console.log(index)
            }
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述
8.v-model
获取和设置表单元素的值(双向数据绑定),绑定的数据会和表单元素值相关联。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>document</title>
</head>
<body>
    <script src="https://unpkg.com/vue@3/dist/vue.global.js"></script>
    <div id="app">
        <input type="text" v-model="message" @keyup.enter="showmassage">
        <br>
        {{message}}

        <input type="button" value="changemassage" @click="changemassage">
    </div>

    <script>
        const { createApp } = Vue
        createApp({
        data() {
            return{
                message:"hello!"
            }
        },
        methods:{
            showmassage:function(){
                alert(this.message)
            },
            changemassage:function(){
                this.message = "hi!"
            }
        }
    }).mount('#app')
    </script>
    
</body>

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/384082.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Unity Asset Bundle学习 - 加载网络资源

昨天调试了一下加载本地资源 Unity Asset Bundle学习 - 加载本地资源 今天试一下用Asset Bundle加载网络数据 接着按照文档走 发现 有问题 引用命名空间一直报错 按文档走不通 就直接百度查了 查了好多 这个东西有很多前辈的经验 直接拷贝代码拿过来用的 下面这段是测试没问题…

技术分享 | OceanBase 集群扩容缩容

作者&#xff1a;杨文 DBA&#xff0c;负责客户项目的需求与维护&#xff0c;会点数据库&#xff0c;不限于MySQL、Redis、Cassandra、GreenPlum、ClickHouse、Elastic、TDSQL等等。 本文来源&#xff1a;原创投稿 *爱可生开源社区出品&#xff0c;原创内容未经授权不得随意使用…

面试官:为什么说ArrayList线程不安全?

本博客知识点收录于&#xff1a;⭐️《JavaSE系列教程》⭐️ 1&#xff09;线程安全与不安全集合 我们学习集合的时候发现集合存在由线程安全集合和线程不安全集合&#xff1b;线程安全效率低&#xff0c;安全性高&#xff1b;反之&#xff0c;线程不安全效率高&#xff0c;安…

Yuga Labs发布“TwelveFold“进军BTC,新大陆的探索即将开启

Yuga Labs 正在将新的 NFT 引入比特币区块链&#xff0c;并于 2 月 28 日推出了一个名为 TwelveFold 的系列。该系列是比特币网络上“刻在 satoshis 上”的 300 个生成作品的限量版。据官方说明&#xff0c;TwelveFold将限量发行三百幅的生成式NFT 画作&#xff0c;每件NFT 作品…

AcWing3696. 构造有向无环图

先看题&#xff1a; 首先来看一下题目的要求&#xff1a;利用给定的边来构造一个有向无环图。 那么什么是有向无环图呢&#xff1f;我们来搜索一番&#xff1a;"所谓有向无环图其实就是&#xff1a;有方向的边&#xff1b;这些边在一个图中不会构成一个闭合的环路。"…

学习大数据应该掌握哪些技能

想要了解大数据开发需要掌握哪些技术&#xff0c;不妨先一起来了解一下大数据开发到底是做什么的~ 1、什么是大数据&#xff1f; 关于大数据的解释&#xff0c;比较官方的定义是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合&#xff0c;是需要新处理模…

C++STL详解(四)—— vector模拟实现

文章目录vector内置成员变量默认成员函数初始化列表构造迭代器区间构造函数赋个数赋值构造函数赋值构造的相关问题拷贝构造函数赋值运算符重载函数析构函数迭代器及迭代器相关函数begin和end范围for容量与扩容相关函数size和capacityreserveresizeemptyvector中的增删查改&…

「攻略手册」:ShardingSphere 与 Java 应用性能优化

笔者曾经写过一篇文章&#xff0c;介绍 ShardingSphere 在具体代码细节上的优化案例&#xff0c;但文章中没有介绍如何发现代码优化点。本文将结合之前笔者在 ShardingSphere 相关性能问题排查、优化经验&#xff0c;简要地介绍 ShardingSphere 性能问题排查、优化应如何入手。…

解决Sql WorkBench中数据库不能重命名的问题

解决Sql WorkBench中数据库不能重命名的问题mysql不支持直接重命名数据库1. 连接到数据库2. 打开菜单&#xff0c;选择迁移向导3. 点击Start Migration4. 填写源数据库的相应参数5. 填写目标数据库的响应参数6. 稍等片刻&#xff0c;点击Next7. 选择你要迁移的数据库。8. 进入一…

B站依然面临巨大风险,盈利之路可能会更加艰难

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 哔哩哔哩(BILI)虽然得到了阿里巴巴(BABA)和腾讯(00700)的支持&#xff0c;在扩大和多样化用户数量方面也取得了巨大的成绩。但哔哩哔哩还在继续亏损&#xff0c;随着国家的监管环境朝着对游戏行业有利的方向变化&#xff0…

【案例教程】GAMS电力模型

本专题主要针对电力系统领域中比较典型的优化问题、优化方法及其在GAMS中的实现进行分析。共分为五个部分&#xff0c;包括电力系统机组组合专题、最优潮流专题、水电优化运行专题、鲁棒优化和多能源互补优化专题、分布鲁棒优化专题等&#xff0c;从基本模型到复杂模型逐步深入…

MySql数据类型都是字符串(varchar),数据类型一样,但是联表查询不走索引,是什么原因呢

大家都知道,如果联表查询中,数据类型不一样,是很有可能不走索引的,但是有时候数据类型一样也是有可能不走索引的,我们往下看1 数据准备我们准备两个表,用来模拟联表查询1.1 user表CREATE TABLE user (id bigint(20) NOT NULL AUTO_INCREMENT COMMENT 主键,phone varchar(20) DE…

华为OD机试用Python实现 -【几何平均值最大子数组】| 2023年3月被抽中

华为OD机试题 最近更新的博客华为 OD 机试 300 题大纲几何平均值最大子数组题目描述输入描述输出描述说明示例一输入输出说明示例二输入输出说明Python 代码实现核心逻辑最近更新的博客 华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单</

测试只能干到35岁?35岁+的测试就会失业?

互联网行业在很多年轻人的眼中&#xff0c;是高薪的象征。前几年的软件测试行业还是一个风口&#xff0c;随着不断地转行人员以及毕业的大学生疯狂地涌入软件测试行业&#xff0c;但是现在裁员潮涌现的时候&#xff0c;互联网行业首当其冲&#xff0c;互联网企业大量的裁员&…

当你开始学习 Python 时,这是一个简单的学习计划及当你初学 Python 时,这里有几个建议

当你开始学习 Python 时&#xff0c;这是一个简单的学习计划&#xff1a; 1.入门 安装Python环境并熟悉基本的Python语法 熟悉Python的基本数据类型&#xff0c;例如数字、字符串和列表 学习控制流程&#xff0c;例如条件语句和循环语句 掌握函数和模块的基本知识 2.进阶 …

Qt开发基本步骤示例:输入半径显示圆的面积

目录 1. 创建一个新项目 1.1 创建类的基类 1.2 main.cpp代码释义 2. 代码写在哪&#xff1f; 2.1 怎么找到我们需要的函数&#xff1f; 1. 创建一个新项目 点击创建项目&#xff0c;开始创建&#xff1a; 1.1 创建类的基类 QMainWindow&#xff1a;带菜单栏的窗口QWidge…

第一章——冯·诺伊曼结构计算机工作原理及层次结构分析

&#x1f3e1;个人主页 &#xff1a; 守夜人st &#x1f680;系列专栏&#xff1a;计算机组成原理 …持续更新中敬请关注… &#x1f649;博主简介&#xff1a;软件工程专业&#xff0c;在校学生&#xff0c;写博客是为了总结回顾一些所学知识点 目录第一章——冯诺伊曼结构计算…

深入浅出RPC框架-学习笔记

1 基本概念 1.1 本地函数调用 1.2 远程函数调用 1.3 RPC概念模型 5个模型组成&#xff1a;User、User-Stub、RPC-Runtime、Server-Stub、Server 1.4 一次RPC的完整过程 1.4.1 IDL (Interface description language)文件 IDL通过一种中立的方式来描述接口&#xff0c;使得在不…

JavaScript(1)

JavaScript简介 JavaScript是一门跨平台、面向对象的脚本语言&#xff0c;用来控制网页行为的&#xff0c;它能使网页可以交互。 JavaScript引入方式 1、内部脚本 将js代码定义在HTML页面中&#xff0c;在HTML中&#xff0c;JavaScript代码必须位于<script>与</scrip…

用C语言写一个自己的shell-Part Ⅱ--execute commands

Part Ⅱ–execute commands Exec This brings us to the exec family of functions. Namely, it has the following functions: execlexecvexecleexecveexeclpexecvp For our needs,we will use execvp whose signature looks like this int execvp(const char *file, cha…