## 功能介绍
- 全端支持(含 `v3、NVUE`)
- 支持丰富的标签(包括 `table`、`video`、`svg` 等)
- 支持丰富的事件效果(自动预览图片、链接处理等)
- 支持设置占位图(加载中、出错时、预览时)
- 支持锚点跳转、长按复制等丰富功能
- 支持大部分 *html* 实体
- 丰富的插件(关键词搜索、内容 **编辑** 等)
- 效率高、容错性强且轻量化
查看 [功能介绍](https://jin-yufeng.gitee.io/mp-html/#/overview/feature) 了解更多
## 使用方法
- 源码方式
1. 点击上方的使用 `HBuilder X` 导入插件或将下载的插件包拷贝到项目根目录下
由于插件市场的 **非 uni_modules 版本** 无法更新,若需使用请从 [github](https://github.com/jin-yufeng/mp-html/tree/master/dist/uni-app) 或 [gitee](https://gitee.com/jin-yufeng/mp-html/tree/master/dist/uni-app) 获取最新版本
2. 在需要使用页面的 `(n)vue` 文件中添加
```html
<mp-html :content="html" />
```
```javascript
import mpHtml from '@/components/mp-html/mp-html'
export default {
// HBuilderX 2.5.5+ 可以通过 easycom 自动引入
components: {
mpHtml
},
data() {
return {
html: '<div>Hello World!</div>'
}
}
}
```
- npm 方式
1. 在项目根目录下执行
```bash
npm install mp-html
```
2. 在需要使用页面的 `(n)vue` 文件中添加
```html
<mp-html :content="html" />
```
```javascript
import mpHtml from 'mp-html/dist/uni-app/components/mp-html/mp-html'
export default {
// 不可省略
components: {
mpHtml
},
data() {
return {
html: '<div>Hello World!</div>'
}
}
}
```
使用 *cli* 方式运行的项目,通过 *npm* 方式引入时,需要在 *vue.config.js* 中配置 *transpileDependencies*,详情可见 [#330](https://github.com/jin-yufeng/mp-html/issues/330#issuecomment-913617687)
如果在 **nvue** 中使用还要将 `dist/uni-app/static` 目录下的内容拷贝到项目的 `static` 目录下,否则无法运行
查看 [快速开始](https://jin-yufeng.gitee.io/mp-html/#/overview/quickstart) 了解更多
## 组件属性
| 属性 | 类型 | 默认值 | 说明 |
|:---:|:---:|:---:|---|
| container-style | String | | 容器的样式([2.1.0+](https://jin-yufeng.gitee.io/mp-html/#/changelog/changelog#v210)) |
| content | String | | 用于渲染的 html 字符串 |
| copy-link | Boolean | true | 是否允许外部链接被点击时自动复制 |
| domain | String | | 主域名(用于链接拼接) |
| error-img | String | | 图片出错时的占位图链接 |
| lazy-load | Boolean | false | 是否开启图片懒加载 |
| loading-img | String | | 图片加载过程中的占位图链接 |
| pause-video | Boolean | true | 是否在播放一个视频时自动暂停其他视频 |
| preview-img | Boolean | true | 是否允许图片被点击时自动预览 |
| scroll-table | Boolean | false | 是否给每个表格添加一个滚动层使其能单独横向滚动 |
| selectable | Boolean | false | 是否开启文本长按复制 |
| set-title | Boolean | true | 是否将 title 标签的内容设置到页面标题 |
| show-img-menu | Boolean | true | 是否允许图片被长按时显示菜单 |
| tag-style | Object | | 设置标签的默认样式 |
| use-anchor | Boolean | false | 是否使用锚点链接 |
查看 [属性](https://jin-yufeng.gitee.io/mp-html/#/basic/prop) 了解更多
## 组件事件
| 名称 | 触发时机 |
|:---:|---|
| load | dom 树加载完毕时 |
| ready | 图片加载完毕时 |
| error | 发生渲染错误时 |
| imgtap | 图片被点击时 |
| linktap | 链接被点击时 |
查看 [事件](https://jin-yufeng.gitee.io/mp-html/#/basic/event) 了解更多
## api
组件实例上提供了一些 `api` 方法可供调用
| 名称 | 作用 |
|:---:|---|
| in | 将锚点跳转的范围限定在一个 scroll-view 内 |
| navigateTo | 锚点跳转 |
| getText | 获取文本内容 |
| getRect | 获取富文本内容的位置和大小 |
| setContent | 设置富文本内容 |
| imgList | 获取所有图片的数组 |
查看 [api](https://jin-yufeng.gitee.io/mp-html/#/advanced/api) 了解更多
## 插件扩展
除基本功能外,本组件还提供了丰富的扩展,可按照需要选用
| 名称 | 作用 |
|:---:|---|
| audio | 音乐播放器 |
| editable | 富文本编辑([示例项目](https://6874-html-foe72-1259071903.tcb.qcloud.la/editable.zip?sign=cc0017be203fb3dbca62d33a0c15792e&t=1608447445)) |
| emoji | 解析 emoji |
| highlight | 代码块高亮显示 |
| markdown | 渲染 markdown |
| search | 关键词搜索 |
| style | 匹配 style 标签中的样式 |
| txv-video | 使用腾讯视频 |
| img-cache | 图片缓存 by [@PentaTea](https://github.com/PentaTea) |
从插件市场导入的包中 **不含有** 扩展插件,需要使用插件参考以下方法:
1. 获取完整组件包
```bash
npm install mp-html
```
2. 编辑 `tools/config.js` 中的 `plugins` 项,选择需要的插件
3. 生成新的组件包
在 `node_modules/mp-html` 目录下执行
```bash
npm install
npm run build:uni-app
```
4. 拷贝 `dist/uni-app` 中的内容到项目根目录
查看 [插件](https://jin-yufeng.gitee.io/mp-html/#/advanced/plugin) 了解更多
## 示例体验
![富文本插件](https://gitee.com/jin-yufeng/mp-html/raw/master/docs/assets/case/富文本插件.jpg)
## 关于 nvue
`nvue` 使用原生渲染,不支持部分 `css` 样式,为实现和 `html` 相同的效果,组件内部通过 `web-view` 进行渲染,性能上差于原生,根据 `weex` 官方建议,`web` 标签仅应用在非常规的降级场景。因此,如果通过原生的方式(如 `richtext`)能够满足需要,则不建议使用本组件,如果有较多的富文本内容,则可以直接使用 `vue` 页面
由于渲染方式与其他端不同,有以下限制:
1. 不支持 `lazy-load` 属性
2. 视频不支持全屏播放
纯 `nvue` 模式下,[此问题](https://ask.dcloud.net.cn/question/119678) 修复前,不支持通过 `uni_modules` 引入,需要本地引入(将 [dist/uni-app](https://github.com/jin-yufeng/mp-html/tree/master/dist/uni-app) 中的内容拷贝到项目根目录下)
## 问题反馈
遇到问题时,请先查阅 [常见问题](https://jin-yufeng.gitee.io/mp-html/#/question/faq) 和 [issue](https://github.com/jin-yufeng/mp-html/issues) 中是否已有相同的问题
可通过 [issue](https://github.com/jin-yufeng/mp-html/issues/new/choose) 、插件问答或发送邮件到 [mp_html@126.com](mailto:mp_html@126.com) 提问,不建议在评论区提问(不方便回复)
提问请严格按照 [issue 模板](https://github.com/jin-yufeng/mp-html/issues/new/choose) ,描述清楚使用环境、`html` 内容或可复现的 `demo` 项目以及复现方式,对于 **描述不清**、**无法复现** 或重复的问题将不予回复
查看 [问题反馈](https://jin-yufeng.gitee.io/mp-html/#/question/feedback) 了解更多
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
商城uniapp端主题源码、支持(微信+支付宝+百度+头条&抖音+QQ)小程序、H5、APP (526个子文件)
page.css 26KB
editor-icon.css 18KB
theme.css 18KB
goods-detail.css 11KB
lib.css 11KB
uniicons.css 8KB
plugins.css 8KB
goods-category.css 7KB
user.css 5KB
iconfont.css 5KB
buy.css 5KB
index.css 4KB
detail.css 4KB
detail.css 3KB
login.css 3KB
user-address-save.css 3KB
goods-search.css 3KB
recharge.css 3KB
cash.css 2KB
index.css 2KB
recharge-pay.css 2KB
detail.css 2KB
design.css 2KB
search.css 2KB
user.css 2KB
user.css 2KB
user.css 2KB
detail.css 1KB
business.css 1KB
index.css 1KB
convert.css 1KB
index.css 1KB
recharge.css 1KB
orderallot-detail.css 1KB
search.css 1KB
user-order-detail.css 1KB
recommend-detail.css 1KB
order.css 1KB
user-orderaftersale-detail.css 1KB
detail.css 1KB
buy.css 1KB
index.css 990B
goods-comment.css 933B
index.css 896B
index.css 892B
map.css 854B
open-setting-location.css 838B
index.css 837B
index.css 831B
index.css 800B
user.css 799B
index.css 794B
user-order.css 782B
order-detail.css 738B
detail.css 718B
detail.css 704B
recommend-form.css 703B
recharge-list.css 682B
order-detail.css 645B
team.css 590B
user-list.css 537B
user-address.css 489B
cash-list.css 484B
detail.css 457B
search.css 446B
scan.css 438B
user-order-comments.css 423B
extraction-order.css 404B
user-orderaftersale.css 382B
goods-list.css 381B
logistics.css 380B
transfer.css 356B
paytips.css 341B
detail.css 327B
index.css 317B
password.css 308B
index.css 302B
collection.css 293B
setup.css 293B
extraction-apply.css 292B
currency.css 285B
order.css 270B
extraction-switch.css 268B
extraction-address.css 268B
transfer-list.css 265B
transaction-list.css 259B
convert-list.css 255B
promotion-user.css 250B
personal.css 246B
user-list.css 226B
user.css 225B
user-goods-comments-form.css 224B
order.css 224B
payment-code.css 212B
member-code.css 212B
invoice.css 211B
goods-comments.css 208B
orderallot-list.css 207B
form.css 201B
shop.css 187B
共 526 条
- 1
- 2
- 3
- 4
- 5
- 6
资源评论
a3737337
- 粉丝: 0
- 资源: 2869
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 过年倒计时动画html过年倒计时代码/春节倒计时网页版【春节倒计时html】
- arm linux tslib 1.23
- 若依python前端定时任务部署
- 基于java的库存管理系统的设计和实现.docx
- 基于java的流浪动物管理系统的设计和实现.docx
- 电动汽车再生制动系统simulink联合Carsim仿真模型,可模拟车辆在不同工况下的车辆各种参数,包含电池SOC,电压、电流、踏板深度、驱动与制动力矩等
- 基于java的码头船只货柜管理系统的设计和实现.docx
- 基于Python开发的bilibili直播弹幕点歌姬
- html+css网页设计 美食 文化美食大联盟5个页面
- 基于A*算法的往返式全覆盖路径规划的改进算法 matlab实现代码 算法一 %%往返式全覆盖路径规划 %通过建立二维栅格地图,设置障碍物,以及起始点 %根据定义往返式路径规划的定义的优先级运动规则从起
- sunyata是一个Python3 RPC框架,client和server既可以直连,也可以通过Consul或ETCD做服务注册发现 适用于 Python 的轻量级、简单、异步 RPC 框架
- 跨年烟花源代码html5-fireworks
- 基于HTTP POST请求的本地应用注册接口实现详解与用途
- Matlab遗传优化算法等算法 求解 生鲜配送问题 路径优化 时间窗 新鲜度 损成本 等约束 程序+算法+参考文献
- HTML5实现好看的二十四节气网页源码.zip
- 基于DDD架构的Java和Python混编项目
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功