【mp-html】小程序富文本组件(页面内嵌html)
创始人
2024-11-10 00:37:51
0

文章目录

  • 前言
  • 一、mp-html是什么?
  • 二、使用方法
    • 1.原生平台
      • 1.npm 方式:
      • 2.源码引入
    • 2.uniapp平台
      • 1.uni-modules 方式
      • 2.源码方式
      • 3.npm 方式
  • 三、应用示例


前言

显示动态 html 富文本是很多应用必要的需求,小程序平台不支持 dom 操作使得这成为一个难题,其自带的 rich-text 组件支持的标签少且屏蔽所有事件,难以实际应用。因此就有了这样一个能够便捷的在小程序平台上处理富文本的组件,还支持丰富的扩展功能。


提示:以下是mp-html正文内容,下面案例可供参考

一、mp-html是什么?

mp-html富文本组件是一个可以在多个主流小程序平台(如微信、QQ、百度、支付宝、头条和uni-app)和uni-app中使用的小程序组件。

这个组件的主要功能有以下几点:

  1. 它能支持富文本的渲染和编辑,这可能包括HTML标签(如tablevideosvg等)、事件效果(如自动预览图片链接处理等)以及锚点跳转长按复制等功能。
  2. 它还支持大部分HTML实体,这使得用户可以在小程序中看到更丰富的内容。
  3. 这个组件还有丰富的插件,例如关键词搜索内容编辑等,这可以大大增强用户的使用体验。
  4. mp-html富文本组件的使用效率高、容错性强且轻量化,安装包大小约为24.5KB,gzipped后只有9KB。

更多属性以可以参考官方文档,例如在原生平台上,可以通过npm方式安装组件包,然后在项目目录下构建npm,并在需要使用该组件的页面的json文件中添加相应的配置信息。

二、使用方法

1.原生平台

1.npm 方式:

本方法仅适用于微信、QQ 小程序

  1. 在小程序项目根目录下通过 npm 安装组件包
npm install mp-html 
  1. 在开发者工具中勾选使用 npm 模块(若没有此选项则不需要)
使用 npm 模块 
  1. 点击构建npm模块
工具 - 构建 npm 
  1. 在需要使用的页面的 json 文件中添加
{   "usingComponents": {     "mp-html": "mp-html"   } } 
  1. 在页面中使用
{html}}">加载中... 
  1. 在需要使用页面的 js 文件中添加
Page({   onLoad() {     this.setData({       html: '
Hello World!
' }) } })

2.源码引入

本方法适用于所有平台

  1. 源码 中对应平台的代码包(dist/platform)拷贝到 components 目录下,更名为 mp-html(获取源码的方式可以查看官方文档)
  2. 在需要使用页面的 json 文件中添加
{   "usingComponents": {     "mp-html": "/components/mp-html/index"   } } 

支持的 属性 和 事件 见对应文档

2.uniapp平台

1.uni-modules 方式

本方法需要使用 3.1.0+ 版本的 HBuilder X 开发

  1. 进入 插件市场,点击右上角的 使用 HBuilder X 导入插件 按钮导入项目或点击 下载插件ZIP 按钮下载插件包并解压到项目的uni_modules/mp-html 目录下
  2. 在需要使用页面的 (n)vue 文件中添加
  
  1. 需要更新版本时在 HBuilder X 中右键 uni_modules/mp-html 目录选择 从插件市场更新 即可

2.源码方式

  1. 将 源码 中 dist/uni-app 内的内容拷贝到 项目根目录
  2. 在需要使用页面的 (n)vue 文件中添加
  

3.npm 方式

  1. 在项目根目录下通过 npm 安装组件包
  2. 在需要使用页面的 (n)vue 文件中添加
  

使用 cli 方式运行的项目,通过 npm 方式引入时,需要在 vue.config.js 中配置 transpileDependencies,详情可见 #330

如果在 nvue 中使用还要将 dist/uni-app/static 目录下的内容拷贝到项目的 static 目录下,否则无法运行

更多方式可查看官方文档


三、应用示例

1,直接在uniapp插件市场下载并导入HBuilderX
在这里插入图片描述

2,在uniapp中创建一个页面,使用mp-html

 

3,在js中引入一个.vue文件,并在组件中声明

import mpHtml from '@/uni_modules/mp-html/components/mp-html/mp-html.vue' 
components: { 	mpHtml }, 

4,定义一个data对应mp-html引用的数据,以及一个远程的html文件的路径,mp-html内容的样式可以定义在tagStyle中

data() { 	return { 		html: '', 		htmlUrl: 'https:baidu/**.html', /*这里是编的*/ 		tagStyle: { 			overflow: 'hidden;', /* 禁用横向滚动 */ 			p: 'font-size: 16px;color:#1F2329: line-heiaht: 1.4; padding:0; margin-block-start: 1.2em; margin-block-end: 1.2em;' 				}, 	} } 

5,定义一个方法使用uniapp的函数(这个函数是用来从指定的URL加载HTML代码),在页面创建时加载html的数据并渲染到页面中

loadExternalHtml() { 	uni.request({ 		url: this.htmlUrl, // 外部HTML页面的URL 		success: (res) => { 			this.html = res.data; 		}, 		fail: (err) => { 			console.error(err); 		}, 	}); }, 
mounted() { 	this.loadExternalHtml(); }, 

相关内容

热门资讯

透视窍门!epoker底牌透视... 透视窍门!epoker底牌透视(透视)cloudpoker怎么开挂(辅助)确实是有工具(哔哩哔哩)1...
透视机巧!佛手在线有挂吗(We... 透视机巧!佛手在线有挂吗(WePoKer分析)一贯真的是有辅助教程(哔哩哔哩)1、佛手在线有挂吗透视...
透视绝活儿!佛手在线大菠萝技巧... 透视绝活儿!佛手在线大菠萝技巧(透视)哈糖大菠萝有挂吗(辅助)一贯真的有神器(哔哩哔哩)1、实时佛手...
开挂了解!手机字牌辅助脚本工具... 开挂了解!手机字牌辅助脚本工具(辅助)66徐州麻将都是是真的辅助器(哔哩哔哩)1、操作简单,无需手机...
透视项目!拱趴游戏破解器(WP... 透视项目!拱趴游戏破解器(WPK德州局)总是真的有辅助软件(哔哩哔哩)透视项目!拱趴游戏破解器(WP...
透视手筋!epoker透视(透... 透视手筋!epoker透视(透视)德州私人局脚本(辅助)好像一直都是有方法(哔哩哔哩)德州私人局脚本...
关于了解!欢乐茶馆免费辅助设置... 关于了解!欢乐茶馆免费辅助设置(辅助)淮安掼蛋大师切实有挂辅助工具(哔哩哔哩)该软件可以轻松地帮助玩...
透视指南!约局吧德州透视(We... 透视指南!约局吧德州透视(WePoKer网页版)一贯有辅助软件(哔哩哔哩)1、约局吧德州透视辅助器安...
透视操作!约局吧德州有挂吗(透... 透视操作!约局吧德州有挂吗(透视)哈糖大菠萝挂(辅助)真是真的是有工具(哔哩哔哩)1、用户打开应用后...
关于了解!荔枝竞技修改器(辅助... 关于了解!荔枝竞技修改器(辅助)亲邻麻将其实真的有辅助平台(哔哩哔哩)1、荔枝竞技修改器辅助器安装包...