【HarmonyOS NEXT】lv-markdown-in 三方库用法说明

📚 简介

鸿蒙原生Markdown解析预览库,可在OpenHarmony、HarmonyOS系统运行,​​兼容api9(1.x.x版本)、api10及以上(2.x.x版本),支持3种内容加载模式(纯文本、资源文件、沙箱文件)​​​ ,​​​支持html常用标签解析​​​,致力于更便捷的OpenHarmony设备的Markdown内容解析,鸿蒙生态三方库中心仓:​​@luvi/lv-markdown-in​​。

🍃 使用效果演示

🎁 lv-markdown-in 目前支持

基本语法 拓展语法
​标题​ ​表格​
​段落​ ​代码块​
​换行​ ​脚注​
​强调(粗体、斜体、粗斜体)​ ​任务列表​
​引用块​ ​删除线​
​列表​ ​支持html常用标签解析​
​代码​
​分割线​
​链接​
​图片​

🔥 版本说明【重要】

1.x.x 版本系列兼容 ​​API9​

2.x.x - 2.0.2 版本系列兼容 ​​API10及以上​

2.0.3 及以上版本系列兼容 ​​API11及以上​

🍺 lv-markdown-in 安装

1.运行命令

ohpm install @luvi/lv-markdown-in

2.在项目中引入插件

import { lvMarkdownIn } from @luvi/lv-markdown-in

3.在代码中使用

lvMarkdownIn({ text: content.toString() }) // content为文本内容

🍊 3种内容加载模式(纯文本、资源文件、沙箱文件)

1.纯文本模式(text)
lvMarkdownIn({
    text: content.toString(), // content为文本内容
    loadMode: "text", // 默认text可省略
    loadCallBack: { // loadCallBack回调可省略
      success(r: LMICallBack) {
        console.log("luvi-markdown-in > " + r.code, r.message)
      },
      fail(r: LMICallBack) {
        console.error("luvi-markdown-in > " + r.code, r.message)
      }
    }
})
2.资源文件模式(rawfile)

使用资源文件模式,​​需要将 loadMode 字段设置为 rawfile​​,rawfilePath 需要填写模块中 rawfile目录的文件路径,同时需要传递应用上下文context,loadCallBack 为可选参数,用于资源加载时的回调检查。

lvMarkdownIn({
    context: getContext(),  // 资源文件模式必填参数
    loadMode: "rawfile",
    rawfilePath: "t/text.md",
    loadCallBack: {
      success(r: LMICallBack) {
        console.log("luvi-markdown-in > " + r.code, r.message)
      },
      fail(r: LMICallBack) {
        console.error("luvi-markdown-in > " + r.code, r.message)
      }
    }
})
3.沙箱文件模式(sandbox)

使用沙箱文件模式,​​需要将 loadMode 字段设置为 sandbox​​,loadCallBack 为可选参数,用于资源加载时的回调检查。

lvMarkdownIn({
    loadMode: "sandbox",
    sandboxPath: getContext().getApplicationContext().filesDir + "/t2/text.md",
    loadCallBack: {
      success(r: LMICallBack) {
        console.log("luvi-markdown-in > " + r.code, r.message)
      },
      fail(r: LMICallBack) {
        console.error("luvi-markdown-in > " + r.code, r.message)
      }
    }
})

🍊 超链接、图片点击拦截,自定义控制跳转行为

需要注意的是,使用拦截行为后,​​return false​​​才可拦截正常拦截库中默认打开行为,​​return true​​则不拦截,但会进入该逻辑。

// 导入 mdRegister
import { mdRegister } from '@luvi/lv-markdown-in'

// 注册超链接点击回调、return false 则表示拦截,自行处理超链接跳转逻辑
mdRegister.HandleHyperlink = (url: string) => {
    console.log("拦截跳转 > " + url)
    return false
}

// 注册图像点击回调、return false 则表示拦截,自行处理图像展示逻辑
mdRegister.HandleImage = (url: string) => {
    console.log("拦截打开图像 > " + url)
    return false
}

🍊 动态样式改变

在页面加载完成后动态改变样式,以 ​​lvText​​​ 字体样式为例,在自定义组件中需要使用 ​​@State​​​ 装饰 ​​lvText​​​,类型为 ​​LvText​​,后续使用新属性修改样式即可,示例代码如下。

// 导入 lvTitle
import { lvTitle, LvText } from '@luvi/lv-markdown-in'

// @State装饰 lvText
@State newText: LvText = lvText

// 动态改变字体颜色
Button("改变lvText.setTextColor").onClick(() => {
    this.newText.setTextColor("blue")
})

📦 自定义样式

1.标题样式(lvTitle)
// 导入 lvTitle
import { lvTitle } from '@luvi/lv-markdown-in'
// 用法
lvTitle.setLevel1Title(50)            // 设置一级标题字号50
lvTitle.setLevelTitleColor("blue")    // 设置标题字体颜色为蓝色
方法 说明 参数
setLevel1Title() 设置 1 级标题字号 number / string 默认:32
setLevel2Title() 设置 2 级标题字号 number / string 默认:29
setLevel3Title() 设置 3 级标题字号 number / string 默认:26
setLevel4Title() 设置 4 级标题字号 number / string 默认:23
setLevel5Title() 设置 5 级标题字号 number / string 默认:20
setLevel6Title() 设置 6 级标题字号 number / string 默认:17
setLevelTitleColor() 设置标题字体颜色 string 默认:"#303133"
2.文字样式(lvText)
// 导入 lvText
import { lvText } from '@luvi/lv-markdown-in'
// 用法
lvText.setTextSize(20)                   // 设置文本字号20
lvText.setTextColor("red")               // 设置文本颜色为红色
lvText.setTextMarkBackground("#000")     // 设置标记文本的背景颜色为黑色
lvText.setTextLineHeight("25")           // 设置标记文本的行高
方法 说明 参数
setTextSize() 设置文本字号 number / string 默认:15
setTextColor() 设置文本颜色 string 默认:"#303133"
setTextMarkBackground() 设置标记文本的背景颜色 string 默认:"#7cff8321"
setTextLineHeight() 设置标记文本的行高 string 默认:"24"
3.超链接样式(lvLink)
// 导入 lvLink
import { lvLink } from '@luvi/lv-markdown-in'
// 用法
lvLink.setTextSize(20)            // 设置超链接文本字号20
lvLink.setTextColor("red")        // 设置超链接文本颜色为红色
lvLink.setTextUnderline(true)     // 设置超链接下划线
方法 说明 参数
setTextSize() 设置超链接文本字号 number / string 默认:15
setTextColor() 设置超链接文本颜色 string 默认:"#3A8AEB"
setTextUnderline() 设置超链接下划线 boolean 默认:false
4.图片样式(lvImage)

需要注意的是:若在md文本内容中未单独设置图片宽高,将采用默认全局宽高,可通过 setImgWidth() 与 setImgHeight()进行设置。若强制开启图片全局宽高将会覆盖所有图片的宽高,即使在md文本内容中已设置图片宽高,可通过 setConfGloable() 进行设置

// 导入 lvImage
import { lvImage } from '@luvi/lv-markdown-in'
// 用法
lvImage.setImgWidth("70%")         // 设置图片宽度为70%
lvImage.setImgHeight(null)         // 设置图片高度为null
lvImage.setConfGlobal(true)        // 强制开启图片全局宽高
方法 说明 参数
setImageWidth() 设置图片宽度 number / string 默认:"60%"
setImageHeight() 设置图片高度 string 默认:null
setConfGlobal() 强制开启全局宽高 boolean 默认:false
5.代码块(lvCode)

提供 ​​暗夜​​​ 与 ​​明亮​​ 双主题,同时可设置索引列的展示与隐藏。

// 导入 lvCode
import { lvCode } from '@luvi/lv-markdown-in'
// 用法
lvCode.setTheme("dark")         // 设置代码块主题为暗夜
lvCode.setIndexState(true)      // 展示代码块索引列
方法 说明 参数
setTheme() 设置代码块主题 string: "dark" / "light" 默认:"dark"
setIndexState() 设置索引列的展示与隐藏 boolean 默认:"false"
6.引用块样式(lvQuote)

需要注意的是引用块中字体大小与字体颜色,请使用 ​​lvText​​ 进行设置

// 导入 lvQuote
import { lvQuote } from '@luvi/lv-markdown-in'
// 用法
lvQuote.setBackgroundColor("rgba(234, 239, 255, 0.62)")      // 设置引用块背景颜色为淡粉色
lvQuote.setBorderColor("red")                                // 设置引用块左边颜色为红色
方法 说明 参数
setBackgroundColor() 设置引用块背景颜色 string 默认:"rgba(234, 239, 255, 0.62)"
setBorderColor() 设置引用块左边颜色 string 默认:"#409EFF"
7.其他样式

需要注意的是列表、表格、任务列表、脚注、删除线、引用块等语法中字体大小与字体颜色,请使用 ​​lvText​​ 进行设置

🍺 CSDN同步文章

详细用法请参考CSDN文章:​​lv-markdown-in for CSDN​

🍺 其他

有关Markdown的更多信息,请参阅Markdown官方教程 ​​Markdown​

使用过程中发现任何问题都可以提 ​​Issues​​。

🍺 版权声明

本项目采用 MIT 开源协议,允许商用,修改,再分发。再分发时请注明原作者及原仓库地址。

全部评论

相关推荐

2024-12-12 02:38
门头沟学院 后端
先说说我的情况吧,我的学历是民办二本,我也知道学校不好,所以我没指望过靠学校的什么光环或者说靠学校的招聘会什么的,也是一直从大一寒假开始,直到现在一直学的Java,其实我到大二暑假的时候就已经接触微服务了,可是当时学得不怎么扎实,八股文也是大三就知道有这么个东西了,期间也是断断续续的看,就是效率不咋高,因为我平常没啥总结的,就是看到啥算啥,现在想着有有点后悔的,早知道一开始就扎扎实实的学了,项目也是实操得少,简单过了一遍 看了视频 大致了解过程 当时我想得是赶快过几个项目,然后就马上去找实习,结果是boss找实习根本面试都没几个,还是暑假的时候去了一家外包实习就是亚信科技,但是也没学什么,简历也是包装了,现在简历就是一段实习,然后两个烂大街的项目,然后现在八股也在看,但是我是真的不想直接背,还是想理解为主,所以其实八股没怎么认真看过,一直在看视频学习,还买了很多书,想着好好看一下,平常也做好笔记,扎扎实实学好,但是现在看来感觉没啥时间了,我现在已经是大四了,真不知道该怎么办了,不知道是好好沉淀备战春招呢,还是说去找个实习再加一段实习经历呢?之前有两个实习我因为我一直想着沉淀,而且是外包,而且还是外地,就一直没想着去,现在感觉有那么点后悔了,其实是不是混段经历也不错呢 还是武汉3500 上海3300包住的 虽然是外包,但是薪资还行吧,但是我都放弃了,还有一个本地的,就是要去工厂里面驻场,也是放弃了,现在也是焦虑得不得了,不知道怎么办了,现在家里还有驾照要考,唉,都凑在一块了。兄弟们你们说到底怎么办呢,兄弟们,客观来说,我接下来应该怎么办呢?😭😭😭
KPLACE:我一样,但是事情得一件一件来,不重要的先放掉,我们不可能每一件事都做好,找准一两件再去做
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务