当前位置: 首页 > news >正文

05 动态渲染数据

概述

实际上动态渲染数据,在《使用CDN开发Vue3项目》中就已经学习过了,核心代码如下:

<div id="vue-app">{{text}}</div>
<script src="https://cdn.staticfile.org/vue/3.0.5/vue.global.js"></script>
<script>const app = Vue.createApp({data() {return {text: "今天就开始使用 Vue.js!",};},});app.mount("#vue-app");
</script>

从上面的代码,我们可以分析出,要实现动态渲染数据,需要遵循以下步骤:

  • 第一步:在data中定义变量,比如这里的text
  • 第二步:在模板中使用两个大括号包裹变量,比如这里的{{text}}

以上的两个步骤是比较核心的步骤,不过在Vue3的setup语法中,有一点点的区别,那就是在setup中可以直接定义变量,而不需要在data中声明变量。

渲染变量的核心步骤

在Vue中的setup语法中要渲染变量,只需要遵循以下步骤即可:

第一步:声明变量,比如

const msg = "欢迎跟着Python私教一起学习Vue3入门课程"

第二步:渲染变量,比如

<div>{{msg}}
</div>

编写我们的组件

为了便于查阅代码,我在本门课程中,所有的组件统一使用”Demoxx“开头,xx表示编号,比如本节课是第05节课,那么xx就是05。

所以,我们创建/src/component/Demo05Msg.vue组件,并在组件中填写如下代码:

<script setup>
// 第一步:定义变量
const msg = "欢迎跟着Python私教一起学习Vue3入门课程"
</script><template><!--第二步:渲染变量--><div>{{ msg}}</div>
</template>

接着,我们只需要在src/App.vue中,引入该组件并进行渲染即可。为了便于代码的规范,我们引入以后,统一重命名为Demo,这样做的好处是,以后我们在App.vue中要查看不同组件的渲染效果的时候,只需要修改组件的编号,而不需要对模板进行修改。

比如,我们将src/App.vue中的代码改写如下:

<script setup>
import Demo from "./components/Demo05Msg.vue"
</script>
<template><h1>欢迎跟着Python私教一起学习Vue3入门课程</h1><hr><Demo/>
</template>

此时,我们启动服务,浏览器访问:http://localhost:5173/

在这里插入图片描述

完整代码

package.json

{"name": "hello","private": true,"version": "0.1.0","type": "module","scripts": {"dev": "vite","build": "vite build"},"dependencies": {"vue": "^3.3.8"},"devDependencies": {"@vitejs/plugin-vue": "^4.5.0","vite": "^5.0.0"}
}

vite.config.js

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'export default defineConfig({plugins: [vue()],
})

index.html

<!doctype html>
<html lang="en"><head><meta charset="UTF-8" /><link rel="icon" type="image/svg+xml" href="/vite.svg" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Vite + Vue</title></head><body><div id="app"></div><script type="module" src="/src/main.js"></script></body>
</html>

src/main.js

import { createApp } from 'vue'
import App from './App.vue'createApp(App).mount('#app')

src/App.vue

<script setup>
import Demo from "./components/Demo.vue"
</script>
<template><h1>Vite5+Vue3</h1><div class="container"><Demo/></div>
</template>

src/components/DemoMsg.vue

<script setup>
// 第一步:定义变量
const msg = "欢迎跟着Python私教一起学习Vue3入门课程"
</script><template><!--第二步:渲染变量--><div>{{ msg}}</div>
</template>

启动方式

yarn
yarn dev

浏览器访问:http://localhost:5173/

相关文章:

  • Flink系列之:窗口去重
  • 科技的成就(五十四)
  • Linux:TCP 序列号简介
  • php的Url 安全的base64编码解码类
  • ACM32如何保护算法、协议不被破解或者修改
  • C练习题_3答案
  • [论文笔记] chatgpt系列 SparseMOE—GPT4的MOE结构
  • beebox靶场A1 low 命令注入通关教程(上)
  • 【PostgreSQL】从零开始:(二)PostgreSQL下载与安装
  • 【5G PHY】5G小区类型、小区组和小区节点的概念介绍
  • 音频I2S
  • 08-工厂方法
  • mybatis中oracle的sql没走索引导致特别慢(未加jdbcType的)
  • Nat. Mach. Intell. | 通过深度神经网络联合建模多个切片来构建一个三维全生物体空间图谱
  • jenkins安装
  • [ 一起学React系列 -- 8 ] React中的文件上传
  • [Vue CLI 3] 配置解析之 css.extract
  • JavaScript对象详解
  • SQL 难点解决:记录的引用
  • vue和cordova项目整合打包,并实现vue调用android的相机的demo
  • web标准化(下)
  • 解析带emoji和链接的聊天系统消息
  • 七牛云 DV OV EV SSL 证书上线,限时折扣低至 6.75 折!
  • 如何使用 OAuth 2.0 将 LinkedIn 集成入 iOS 应用
  • 如何学习JavaEE,项目又该如何做?
  • 三分钟教你同步 Visual Studio Code 设置
  • 物联网链路协议
  • 交换综合实验一
  • 通过调用文摘列表API获取文摘
  • ​520就是要宠粉,你的心头书我买单
  • ​DB-Engines 12月数据库排名: PostgreSQL有望获得「2020年度数据库」荣誉?
  • ​MySQL主从复制一致性检测
  • # 数据结构
  • #《AI中文版》V3 第 1 章 概述
  • #Z0458. 树的中心2
  • (floyd+补集) poj 3275
  • (Java实习生)每日10道面试题打卡——JavaWeb篇
  • (Matlab)遗传算法优化的BP神经网络实现回归预测
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • (算法)前K大的和
  • (五)Python 垃圾回收机制
  • (一)Spring Cloud 直击微服务作用、架构应用、hystrix降级
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • (转)重识new
  • .net core 控制台应用程序读取配置文件app.config
  • .NET Core/Framework 创建委托以大幅度提高反射调用的性能
  • .Net 应用中使用dot trace进行性能诊断
  • .NET:自动将请求参数绑定到ASPX、ASHX和MVC(菜鸟必看)
  • .NET建议使用的大小写命名原则
  • .pyc文件还原.py文件_Python什么情况下会生成pyc文件?
  • [AutoSAR 存储] 汽车智能座舱的存储需求
  • [BZOJ5125]小Q的书架(决策单调性+分治DP+树状数组)
  • [C#]winform部署yolov9的onnx模型
  • [Fri 26 Jun 2015 ~ Thu 2 Jul 2015] Deep Learning in arxiv
  • [Java]快速入门优先队列(堆)手撕相关面试题