站在Vue的角度,對比鴻蒙開發中的數據渲染二

第二類數字(Number)的操作?

2.1普通數字的顯示

vue中直接顯示
<template>
<div><h3>學習Vue</h3><div>{{ num }}</div>
</div></template><script lang="ts" setup>import  {ref} from  "vue"
const   num  = ref(10)</script>
Harmony中 有數據類型的約束,是有數字類型的組件中才有用,也不能直接使用

錯誤一

錯誤二 Text組件只能放字符串

正確的寫法? Text里面接受字符串? ?height里面接受數字類型? 鴻蒙中是強語言數據類型

@Entry
@Component
struct MyString {@State  num:number  = 10build() {Column() {Text(`${this.num}`).height(this.num)}.height('100%').width('100%')}
}

2.2 數字的計算

vue中 {{}} 兩個大括號中可以直接計算? ?
<template>
<div><h3>學習Vue</h3><div>{{ num +n}}</div>
</div></template><script lang="ts" setup>import  {ref} from  "vue"
const   num  = ref(10)
const  n  = ref(100)</script>
Harmony中 變量的也可以直接操作,但是也需要組件支持數字類型
@Entry
@Component
struct MyString {@State  num:number  = 10;@State  n:number  = 100;build() {Column() {Text(`${this.num+this.n}`).height(this.num)}.height('100%').width('100%')}
}

巧妙的使用``? ?模版字符串 中${}里面可以放表達式計算

2.3 與表單元素的綁定和字符串操作一樣

不清楚的看上一篇文章 v-model和$$的故事,注意數據類型的匹配,不然鴻蒙中會報錯

再看第三類布爾值(Boolean)的操作?

第三類? ?布爾值(Boolean)的操作?

這玩意 實際上也就是對錯的操作,對錯針對頁面就是顯示與否,狀態有還是沒有

3.1? Boolean值的顯示

vue中會把布爾值轉成字符串輸出
<template>
<div><h3>學習Vue</h3><div>{{ flag }}</div>
</div></template><script lang="ts" setup>import  {ref} from  "vue"
let flag = ref(true)</script>

Harmony中會把布爾值轉成字符串輸出??

鴻蒙沒辦法直接輸出 boolean 值? 放在Text中,Text又只支持string

@Entry
@Component
struct MyString {@State flag:boolean = truebuild() {Column() {Text(`${this.flag}`)}.height('100%').width('100%')}
}

3.2? Boolean判斷顯示

vue中? ?用 v-if? v-else-if? v-else 相關的指令
<template>
<div><h3>學習Vue</h3><div><div v-if="flag">顯示</div><button @click="change">修改狀態</button></div>
</div></template><script lang="ts" setup>
import  {ref} from  "vue"const flag = ref(true);const change  =()=>{flag.value  = !flag.value;
}</script>
Harmony中用 if表達式? ?里面沒有指令了
@Entry
@Component
struct MyString {@State flag:boolean = truebuild() {Column() {if(this.flag){Text(`顯示`)}Button("改變").onClick(()=>{this.flag  = !this.flag})}.height('100%').width('100%')}
}

點擊就可以切換了

3.3?Boolean 判斷顯示2

vue中? ?v-show的控制? ?常見vue問題 v-if和v-show的區別
<template>
<div><h3>學習Vue</h3><div><div v-show="flag">顯示</div><button @click="change">修改狀態</button></div>
</div></template><script lang="ts" setup>
import  {ref} from  "vue"const flag = ref(true);const change  =()=>{flag.value  = !flag.value;
}</script>

區別? if不滿足沒有真實DOM? show的都會有

Harmony中用?visibility的屬性方法來解決? 配合三元(三目)運算符
@Entry
@Component
struct MyString {@State flag:boolean = truebuild() {Column() {Text(`顯示`).visibility(this.flag? Visibility.Visible:Visibility.Hidden)Button("改變").onClick(()=>{this.flag  = !this.flag})}.height('100%').width('100%')}
}

但是為占位置喲

顯示的效果為

不顯示的效果為? 中間有空行

總結

本文對比了Vue和Harmony(鴻蒙)在數字和布爾值操作上的差異。數字操作方面,Vue可直接在模板中顯示和計算數字,而Harmony需要嚴格遵循數據類型約束,通過模板字符串${}進行表達式計算。布爾值操作上,Vue使用v-if/v-show指令控制顯示,Harmony則通過if表達式和visibility屬性實現,其中v-show對應visibility屬性,會保留DOM位置。文章還指出鴻蒙組件對數據類型的強約束性,如Text組件只接受字符串。兩種框架在數據綁定和顯示控制上各有特點,需要開發者注意數據類型匹配和語法差異。

未完待續 歡迎加入?鴻蒙學堂?繼續學習

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/92823.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/92823.shtml
英文地址,請注明出處:http://en.pswp.cn/web/92823.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python自動化測試實戰:reCAPTCHA V3繞過技術深度解析

Python自動化測試實戰&#xff1a;reCAPTCHA V3繞過技術深度解析 摘要 reCAPTCHA V3作為Google推出的無感驗證碼系統&#xff0c;通過先進的機器學習算法分析用戶行為模式&#xff0c;已成為當前最主流的反機器人解決方案。本文將深入解析其核心檢測機制&#xff0c;并提供完…

簡單Modules 的配置與管理,靈活應對多版本軟件環境的需求。

參考文檔 官方手冊&#xff1a;https://modules.readthedocs.io Modulefile 語法&#xff1a;modulefile — Modules documentation Environment Modules 工具 Environment Modules 是一個環境管理工具&#xff0c;用于動態加載、卸載和管理不同版本的軟件環境變量&#xff…

java內部類-匿名內部類

匿名內部類必須有一個已經存在的類或者接口

上篇:《排序算法的奇妙世界:如何讓數據井然有序?》

個人主頁&#xff1a;strive-debug 排序算法精講&#xff1a;從理論到實踐 一、排序概念及應用 1.1 基本概念 **排序**&#xff1a;將一組記錄按照特定關鍵字&#xff08;如數值大小&#xff09;進行遞增或遞減排列的操作。 1.2 常見排序算法分類 - **簡單低效型**&#xff…

2025.8.6 圖論(1)Solution

2025.8.6 圖論&#xff08;1&#xff09;Solution 割點 學習資料&#xff0c;在 csdn 或洛谷上看都行。是模板題題解&#xff08;之一&#xff09;。 T1&#xff1a;Atserckcn與逃離恐怖老師。 題意簡述&#xff1a;從一個圖中選定一個點&#xff0c;使得刪除這個點后圖不連…

OpenBayes 教程上新丨一鍵部署 gpt-oss-20b,實測開源推理模型新 SOTA,性能直逼 o3?mini

時隔 6 年&#xff0c;自 GPT-2 以來&#xff0c;OpenAI 終于再度發布開源大模型——gpt-oss-120b 和 gpt-oss-20b&#xff0c;前者以千億級參數專為復雜推理與知識密集型場景設計&#xff0c;后者則更適合低延遲、本地或專業垂直領域使用&#xff0c;可在消費級硬件&#xff0…

nlp-句法分析

目錄 一、句法概述 1、成分語法理論概述 &#xff08;1&#xff09;分析過程 &#xff08;2&#xff09;缺點 2、依存語法理論概述 &#xff08;1&#xff09;依存關系、配價模式 &#xff08;2&#xff09;分類 &#xff08;3&#xff09;優勢&#xf…

linux磁盤加密

在Linux中&#xff0c;磁盤加密是一種保護數據不被未授權訪問的方法。有多種工具和策略可以實現磁盤加密&#xff0c;包括使用Linux內核的內置功能&#xff0c;如dm-crypt&#xff0c;以及使用更高級的解決方案&#xff0c;如LUKS&#xff08;Linux Unified Key Setup&#xff…

大數據架構演變之路

目錄 一、各階段的架構簡介 二、各個架構的詳細解釋 1. 傳統離線架構 2.1. Lambda架構-離線數倉分析實時鏈路分析 2.2. Lambda架構-離線數倉實時數倉 3. Kappa/流批一體架構 4. 湖倉一體架構 三、總結 一、各階段的架構簡介 技術架構 核心驅動(核心需求) ?關鍵技術 …

STM32 HAL庫驅動0.96寸OLED屏幕

STM32 HAL庫驅動0.96寸OLED屏幕 項目概述 本項目使用STM32 HAL庫為0.96寸OLED屏幕編寫驅動程序。OLED屏幕通過I2C接口與STM32單片機通信&#xff0c;實現文本、數字和圖形的顯示功能。 項目倉庫地址&#xff1a;STM32_Sensor_Drives 硬件連接 OLED屏幕通過I2C接口與STM32連…

橫向越權:修改參數訪問不屬于自己的數據

一、什么是橫向越權定義 橫向越權&#xff08;Horizontal Privilege Escalation&#xff09;是指 同一權限級別的用戶&#xff0c;通過篡改請求參數或資源標識&#xff0c;訪問本不屬于自己的數據或功能。例子 假設一個在線商城&#xff0c;用戶 A 訪問訂單詳情的 URL&#xff…

攻擊實驗(ARP欺騙、MAC洪范、TCP SYN Flood攻擊、DNS欺騙、DHCP餓死)

實驗一 ARP欺騙一、拓撲二、實驗準備、1.設置終端漏洞靶機集合選擇需要的數量和鏡像打開設備上的驅動精靈安裝網卡安裝成功后查看IP地址、網關信息等。三、實驗步驟1.實驗原理中間人&#xff08;攻擊者&#xff09;在終端與網關之間持續發送偽造的 ARP 應答包&#xff0c;雙向欺…

VSCode 禁用更新檢查的方法

通過設置菜單禁用 這是最直接和推薦的方法&#xff0c;可以永久禁用自動更新&#xff1a; 打開 VSCode。點擊左下角的齒輪圖標&#xff0c;然后選擇“設置”。或者通過菜單欄“文件” > “首選項” > “設置”進入。在頂部的搜索框中輸入“update”。找到“Update: Mode”…

Flutter - 應用啟動/路由管理

一、應用入口1. 初始化 Flutter 底層綁定 &#xff0c;運行 App。import package:flutter/material.dart; import package:flutter_base/Application.dart;void main() {// 確保綁定初始化WidgetsFlutterBinding.ensureInitialized();// App初始化Application.init(); }2. 注冊…

MySQL 數據操作全流程:創建、讀取、更新與刪除實戰

MySQL系列 文章目錄MySQL系列前言一、Create(創建)并插入數據1.1 單行數據 全列插入1.2 多行數據 指定列插入1.3 插入沖突時同步更新1.4 沖突時替換二、Retireve讀取數據2.1 全列查詢2.2 查詢指定列2.3 查詢字段為表達式2.4 結果去重 DISTINCT2.5 where條件篩選2.6 order by語…

SQL約束:數據完整性的守護者

在SQL中&#xff0c;約束&#xff08;Constraints&#xff09; 是作用于數據庫表字段上的規則&#xff0c;用于強制保證數據的完整性、準確性和一致性。當插入、更新或刪除數據時&#xff0c;約束會自動驗證操作是否符合規則&#xff0c;若違反則拒絕執行。 以下是SQL中常見的約…

Springboot-vue 地圖展現

在很多社區管理系統中&#xff0c;地圖展示功能是一個重要的模塊&#xff0c;它能直觀地呈現小區的地理位置分布。本文將詳細梳理從前端觸發請求到地圖上展示小區數據的完整流程&#xff0c;幫助大家理解前后端協同工作的具體細節。一、前端觸發&#xff1a;頁面加載與地圖初始…

Vue 3 登錄組件

Login.vue 組件詳細分析整體架構 Vue 3 登錄組件&#xff0c;采用 Composition API Element Plus UI 庫&#xff0c;實現了完整的用戶認證界面。 模板結構分析 1. 容器布局 <div class"login-container"><el-card class"login-card"><!-- …

小結: getSpringFactoriesInstances從 `spring.factories` 文件中加載和實例化指定類型的類

getSpringFactoriesInstances 方法工作原理 getSpringFactoriesInstances 是 Spring Boot 框架中的一個核心方法&#xff0c;用于從 spring.factories 文件中加載和實例化指定類型的類。這是 Spring Boot 實現自動配置和插件化擴展的關鍵機制。 1. 基本功能 該方法的主要作用是…

selenium SessionNotCreatedException問題解決辦法

在上周有一臺服務器重啟之后&#xff0c;Chrome瀏覽器也自動升了級&#xff0c;原本能夠正常使用的自動化辦公程序突然沒法用了&#xff0c;出現了下面的報錯提示。codes/addCancelBdld.py:980: DeprecationWarning: use options instead of chrome_optionsdriver webdriver.C…