vue.js 3: markmap using typescript

在項目目錄文件下,通過cmd運行下述指令。
npm create vue@latest
cd vue-projectnpm installnpm run format
npm run dev或
npm init vue@latest
cd vue-prjectnpm run build --打包項目創建項目沒有node_modules
npm init -y
npm install vue-routernpm install markmap-lib
npm install markmap-render
npm install markmap-view
npm install markmap-cli
npm install markmap-toolbar
npm install coc-markmap
npm i markmap-autoloade

項目結構:

/** @creater: geovindu* @since: 2025-06-24 22:22:55* @LastAuthor: geovindu* @lastTime: 2025-06-24 22:23:29* @文件相對于項目的路徑: \jsstudy\markmapdemo\src\views\markmap.ts* @message: geovindu* @IDE: vscode* @Development: node.js 20, vuejs3.0* @package:* @ISO: windows10* @database: mysql 8.0 sql server 2019 postgresSQL 16* Copyright (c) 2025 by geovindu email:geovindu@163.com, All Rights Reserved.*/
import { loadJS, loadCSS } from 'markmap-common';
import { Transformer } from 'markmap-lib';
import * as markmap from 'markmap-view';// 定義類型
type LoadJS = (scripts: string[],options: { getMarkmap: () => typeof markmap }
) => Promise<void>;type LoadCSS = (styles: string[]) => void;// 創建轉換器實例
export const transformer = new Transformer();
const { scripts, styles } = transformer.getAssets();// 加載資源
const loadJSWithType: LoadJS = (scripts, options) => {return loadJS(scripts, options);
};const loadCSSWithType: LoadCSS = (styles) => {loadCSS(styles);
};loadCSSWithType(styles);
loadJSWithType(scripts, { getMarkmap: () => markmap });

<!--* @creater: geovindu* @since: 2025-06-24 22:24:23* @LastAuthor: geovindu* @lastTime: 2025-06-24 22:39:38* @文件相對于項目的路徑: \jsstudy\markmapdemo\src\views\VueComposition.vue* @message: geovindu* @IDE: vscode* @Development: node.js 20, vuejs3.0* @package:* @ISO: windows10* @database: mysql 8.0 sql server 2019 postgresSQL 16* Copyright (c) 2025 by geovindu email:geovindu@163.com, All Rights Reserved.
-->
<template><div class="flex-1"><textarea class="w-full h-full border border-gray-400" v-model="value" /></div><svg class="flex-1" ref="svgRef" /></template><script lang="ts" setup>import { ref, onMounted, onUpdated } from 'vue';import { Markmap } from 'markmap-view';import { transformer } from './markmap';// 定義類型type MarkmapInstance = Markmap;const initValue = `# 中國行政區劃
## 北京市
### 市轄區
#### 東城區
##### 五道口街道
###### 教苑社區
- 林海花園
- 江海花園
- 學清苑小區
## 江西省
### 吉安市
#### 永豐縣
##### 沿陂鎮
###### 涂家村委
- 涂家村
- 艾家村
- 黃家村
## 廣東省
### 深圳市
#### 羅湖區
##### 東曉街道
###### 蘭心社區
- 江海花園
- 江心花園
- 蘭亭國際
###### 田心社區
- 田心村
- 東曉花園
- 鹿鳴園
##### 桂園街道
###### 大塘龍社區
- 大塘龍小區
- 萬科桂苑
- 天地大廈`;const svgRef = ref<SVGSVGElement | null>(null);const value = ref<string>(initValue);let mm: MarkmapInstance | null = null;const update = async () => {if (!mm || !svgRef.value) return;try {const { root } = transformer.transform(value.value);await mm.setData(root);mm.fit();} catch (error) {console.error('更新Markmap失敗:', error);}};onMounted(() => {if (svgRef.value) {mm = Markmap.create(svgRef.value);update();}});onUpdated(update);</script><style scoped>textarea {font-family: monospace;font-size: 14px;}</style>
<!--* @creater: geovindu* @since: 2025-06-24 22:23:43* @LastAuthor: geovindu* @lastTime: 2025-06-24 22:37:14* @文件相對于項目的路徑: \jsstudy\markmapdemo\src\views\VueLegacy.vue* @message: geovindu* @IDE: vscode* @Development: node.js 20, vuejs3.0* @package:* @ISO: windows10* @database: mysql 8.0 sql server 2019 postgresSQL 16* Copyright (c) 2025 by geovindu email:geovindu@163.com, All Rights Reserved.
-->
<template><div class="flex flex-col h-screen"><div class="flex-1 flex"><textareaclass="w-full h-full border border-gray-400 p-2"v-model="value"placeholder="輸入 Markdown 內容..."/><svg ref="svgRef" class="w-full h-full border border-gray-400" /></div></div>
</template><script lang="ts" setup>
import { ref, onMounted, onUpdated, watch } from 'vue';
import { Markmap } from 'markmap-view';
import { transformer } from './markmap';// 定義類型
type MarkmapInstance = Markmap;// 初始值和狀態
const initValue = `# 中國行政區劃
## 北京市
### 市轄區
#### 東城區
##### 五道口街道
###### 教苑社區
- 林海花園
- 江海花園
- 學清苑小區
## 江西省
### 吉安市
#### 永豐縣
##### 沿陂鎮
###### 涂家村委
- 涂家村
- 艾家村
- 黃家村
## 廣東省
### 深圳市
#### 羅湖區
##### 東曉街道
###### 蘭心社區
- 江海花園
- 江心花園
- 蘭亭國際
###### 田心社區
- 田心村
- 東曉花園
- 鹿鳴園
##### 桂園街道
###### 大塘龍社區
- 大塘龍小區
- 萬科桂苑
- 天地大廈
`;const value = ref(initValue);
const svgRef = ref<SVGSVGElement | null>(null);
let mm: MarkmapInstance | null = null;// 更新 Markmap
const update = async () => {if (!mm || !svgRef.value || !value.value) return;try {const { root } = transformer.transform(value.value);await mm.setData(root);mm.fit();} catch (err) {console.error('更新 Markmap 失敗:', err);}
};// 初始化 Markmap
onMounted(() => {if (svgRef.value) {mm = Markmap.create(svgRef.value);update();}
});// 監聽值變化并更新 Markmap
watch(value, update);// 組件更新后調整 Markmap
onUpdated(() => {if (mm && svgRef.value) {mm.fit();}
});
</script><style scoped>
textarea {font-family: monospace;font-size: 14px;resize: none;
}
</style>
<!--* @creater: geovindu* @since: 2025-06-24 22:24:23* @LastAuthor: geovindu* @lastTime: 2025-06-24 22:43:26* @文件相對于項目的路徑: \jsstudy\markmapdemo\src\views\displayview.vue* @message: geovindu* @IDE: vscode
*npm install markmap-lib
*npm install markmap-render
*npm install markmap-view
*npm install markmap-cli
*npm install markmap-toolbar
*npm install coc-markmap
* npm i markmap-autoloade* @Development: node.js 20, vuejs3.0* @package:* @ISO: windows10* @database: mysql 8.0 sql server 2019 postgresSQL 16* Copyright (c) 2025 by geovindu email:geovindu@163.com, All Rights Reserved.
-->
<template><div class="flex flex-col h-screen p-2"><select class="border border-gray-400" v-model="type"><option value="composition">Composition API</option><option value="legacy">Legacy</option></select><component :is="currentComponent" class="flex-1" /></div>
</template><script lang="ts" setup>
import { ref, computed } from 'vue';
import VueComposition from './VueComposition.vue';
import VueLegacy from './VueLegacy.vue';// 定義類型
type ComponentType = 'composition' | 'legacy';const type = ref<ComponentType>('composition');
const currentComponent = computed(() => {return {composition: VueComposition,legacy: VueLegacy,}[type.value];
});
</script><style scoped>
@import url('https://cdn.jsdelivr.net/npm/tailwindcss@2.2.0/dist/tailwind.min.css');select {padding: 0.5rem;font-size: 1rem;margin-bottom: 0.5rem;
}
</style>

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

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

相關文章

聚寬量化——股票時間序列函數

import matplotlib.pyplot as plt import pandas as pd from mpl_finance import candlestick2_ochl import mplfinance as mpf from unittest import TestCaseclass TestPandasKline(TestCase):#讀取股票數據&#xff0c;畫出K線圖def testKLineChart(self):file_name "…

(一)代碼隨想錄 - 數組

代碼隨想錄 一. 數組的理論基礎 概念&#xff1a;數組是存放在連續內存空間上的相同類型數據的集合 特點&#xff1a;&#xff08;1&#xff09;數組可以通過下標進行訪問對應的數據并且下標是從0開始的 -> 隨機訪問&#xff1b;&#xff08;2&#xff09;數組內存空間的地…

Netty內存池核心PoolArena源碼解析

PoolArena 是 Netty 內存池化機制的核心組件之一&#xff0c;它負責管理一整塊或多塊內存&#xff08;PoolChunk&#xff09;&#xff0c;并將這些內存分配給應用程序。每個 PoolArena 實例都與一個特定的線程相關聯&#xff08;通過 PoolThreadCache&#xff09;&#xff0c;或…

echarts-for-react 日歷熱力圖渲染導致白屏 踩坑記錄

先說結果&#xff0c;補上了一行tooltip.trigger后能正常渲染了。 報錯情況&#xff1a; 在頁面中添加了一個日歷熱力圖后&#xff0c;一渲染它就白屏&#xff0c;控制臺報錯如下&#xff1a; echarts-for-react版本是當前最新的3.0.2&#xff0c;嘗試debug但沒看懂源碼這里是…

SpringBoot項目啟動時自動加載數據到Redis的完整實現方案,用于存儲字典,定時任務,登錄用戶等

一、基礎配置 ?在pom.xml中添加必要依賴&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <dependency><groupId>com.baomi…

python:使用 OpenAI CLIP 模型進行圖像與文本的語義匹配,并用彩虹色帶可視化 CLIP 模型的相似度矩陣

作者&#xff1a;CSDN _養樂多_ 本文將介紹如何使用 OpenAI 的 CLIP 模型來實現圖像與文本之間的語義匹配。代碼使用 Python 語言&#xff0c;加載多個圖像與類別文本&#xff0c;并通過計算余弦相似度判斷每張圖片最匹配的文本標簽。 結果如下圖所示&#xff0c; 文章目錄 …

微服務鏈路追蹤在生產環境問題定位中的實戰經驗

微服務鏈路追蹤在生產環境問題定位中的實戰經驗 在當今復雜的系統架構中&#xff0c;微服務之間相互調用形成的鏈路往往變得極其復雜。一旦出現問題&#xff0c;僅憑日志和監控信息常常難以迅速定位根因。鏈路追蹤技術因此成為生產環境中不可或缺的工具&#xff0c;能夠幫助我…

正點原子——直流無刷電機-霍爾傳感基本實現流程

直流無刷電機-霍爾傳感實現流程 初始化TIM以及IO 霍爾狀態讀取函數 uint32_t hallsersor(void) {uint32_t state 0;if(HAL_GPIO_ReadPin(HALL1_TIM_CH1_GPIO,HALL_TIM_CH1_PIN)!RESET){state |0x01;}if(HAL_GPIO_ReadPin(HALL1_TIM_CH2_GPIO,HALL_TIM_CH2_PIN)!RESET){stat…

小白的進階之路系列之十七----人工智能從初步到精通pytorch綜合運用的講解第十部分

NLP 從零開始:使用字符級 RNN 生成姓名 這是我們“NLP 從零開始”系列三部分教程中的第二部分。在第一個教程中,我們使用了 RNN 將姓名分類到其語言來源。這次我們將反過來,從語言生成姓名。 > python sample.py Russian RUS Rovakov Uantov Shavakov> python sampl…

思辨場域丨AR技術如何重塑未來學術會議體驗?

毫無疑問&#xff0c;增強現實&#xff08;AR&#xff09;已成為科技浪潮中最澎湃的浪花之一。當Pokemon Go點燃全球熱情&#xff0c;我們首次大規模體驗到數字精靈與現實街景的奇妙交融。這不僅是游戲革命&#xff0c;更是一個強烈的信號&#xff1a;虛實共生的交互時代已轟然…

醫學數據分析實戰:冠心病發病因素可視化

一、數據加載與基本信息檢查 #例9.5 import numpy as np import pandas as pd import matplotlib.pyplot as plt import seaborn as sns import warnings#引入第三方庫plt.rcParams[font.sans-serif]=[SimHei] #用來正常顯示中文標簽 warnings.filterwarnings(ignore) #防止…

Proteus8.0 打開前期版本的操作方法

1.打開Proteus8.0 2. 打開菜單File->Import legacy Project 3.在Import Legacy Project 點擊Browse按鈕 4.選擇要打開的例子目錄 5.打開*.dsn文件 6.點擊Import 7.導入成功 點擊運行即可

【innovus基礎】- 對某根線單獨route

在某些特殊需求場景&#xff0c;我們可能需要對某些net進行單獨的route&#xff0c;方法如下&#xff1a; 1、打開design browser&#xff0c;選擇對應net&#xff1a;&#xff08;或者使用selectNet命令&#xff09; 2、Route → nano Route → 勾選selectNet only 可以看到…

【Linux】network網絡配置

目錄 1、介紹2、網絡配置【1】查看【2】說明 3、工作流程【1】啟動以太網接口【2】關閉接口時反向執行 4、現代替換方案 1、介紹 linux中network網絡服務的核心配置位于/etc/sysconfig/network-scripts/目錄下。它們共同構成了網絡接口的管理框架&#xff0c;負責處理網絡接口…

深入解析 Taro 項目結構:從入門到精通

在現代前端開發中&#xff0c;跨平臺開發框架變得越來越重要。Taro 作為一款由京東凹凸實驗室推出的多端統一開發框架&#xff0c;支持編譯到微信小程序、支付寶小程序、百度小程序、H5、React Native 等多個平臺&#xff0c;極大地提高了開發效率。然而&#xff0c;要充分發揮…

零基礎開始的網工之路第二十一天------系統安全基線和系統加固

目錄 一、系統安全基線 1、賬戶與認證安全 2、文件與目錄權限 3、SSH服務安全 4、網絡與服務配置 5、日志與審計 6、內核參數加固 7、更新與補丁 8、安全模塊配置 9、SUID/SGID文件檢查 10、默認權限控制&#xff08;umask&#xff09; 二、系統安全加固 1、賬戶與…

Log4j 和 Log4j2的比較

以下是 Log4j&#xff08;通常指 Log4j 1.x&#xff09;與 Log4j2 的核心對比分析&#xff0c;結合架構、性能、功能及適用場景&#xff0c;幫助開發者做出合理選擇&#xff1a; &#x1f4ca; 一、架構與設計 特性Log4j 1.xLog4j2分析架構模型單模塊設計&#xff0c;耦合度高…

說說 Springboot 的啟動流程?

Spring Boot 的啟動流程是一個相對復雜但有序的過程&#xff0c;它涉及多個組件和步驟的協同工作。以下是 Spring Boot 啟動流程的詳細解析&#xff1a; 一、初始化階段 啟動入口 Spring Boot 應用的啟動入口通常是一個包含 main 方法的類&#xff0c;該類上標注了 SpringBoot…

從服務器收到預料之外的響應。此文件可能已被成功上傳。請檢查媒體庫或刷新本頁

如果php.ini已經加入了如下的內容還是報錯 &#xff1a; upload_max_filesize 1024M post_max_size 1024M 那就是因為阿帕奇導致&#xff1a;

10、java語法糖

編譯期處理&#xff1a;語法糖&#xff08;即java編譯器把。java的源碼編譯成。class字節碼的過程中&#xff0c;自動生成和轉換的一些代碼&#xff0c;主要是為了減輕程序員的負擔&#xff0c;算是java編譯器給我們的一個額外福利-給糖吃&#xff09; 默認構造器&#xff1a;…