Skip to content

移动端HTML文档(富文本)编辑器,支持图文混排、引用、大标题、无序列表,字体颜色、加粗、斜体

Notifications You must be signed in to change notification settings

netsesame2/zx-editor

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

56 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

修复 ZxEditor 的一些bug

移动端HTML文档(富文本)编辑器,支持图文混排、引用、大标题、无序列表,字体颜色、加粗、斜体。

可用于独立web项目开发,也可以用于与原生App混合(hybrid)开发。

ZxEditor

ZxEditor

本地运行 Build Setup

# 安装依赖
npm i

# 运行开发模式
# 通过 `http://localhost:9001` 可以访问
npm run dev

# 生成项目文件
npm run build

使用 Use

# npm

  npm install zx-editor --save-dev

# browser

<div id="editorContainer">
  <!-- 编辑器容器 -->
</div>
<script src="./dist/js/zx-editor.min.js"></script>
<script>
  // 初始化ZX编辑器
  var zxEditor = new ZxEditor('#editorContainer', {
    fixed: true
  })
  // 详见index.html文件
</script>

注意:添加照片时,判断照片方向,并自动旋转需要依赖插件 exif.js

# ES6+

import { ZxEditor } from 'zx-editor'
// import { ZxEditor } from './src/js/zx-editor/index.js'

参数 options

# autoSave: Number

自动保存编辑内容至localStorage,单位秒。等于0则不自动保存编辑内容。

# bottom: Number

底部距离。

# disableBackspaceDelete: Boolean

禁用键盘删除图片、链接等非文本、emoji内容。默认为true。

# fixed: Boolean

编辑器是否绝对定位,默认为false。

imageMaxSize: Number

图片文件最大尺寸限制,单位MB,默认20

# padding: Number

编辑器左右内边距,默认15像素,

# showToolbar: Array|Boolean

是否显示底部工具栏(图片、标签、链接添加等图标)。

默认为true,显示全部图标。

Array可选值:['pic', 'emoji', 'text', 'link'],数组中元素顺序,决定按钮的显示顺序。

# top: Number

顶部距离,绝对定位时,相对于WebView顶部的距离。

属性 property

# dialog: Object

消息提示框,alert、confirm、loading对话框

方法 说明
alert(msg, callback) msg:提示消息, callback():回调函数
confirm(msg, callback) msg:提示消息, callback(true或false):回调函数
loading(msg) msg:提示消息,默认loading...
removeLoading() 移除loading元素节点
zxEditor.dialog.alert('这是alert提示框', function () {
  // do something ...
})

# storage: Object

本地存储,localStorage/sessionStorage

方法 说明
set(key, data, isSessionStorage) key:存储键名,会自动加默认前缀, data:需要存储的数据
get(key, isSessionStorage) key:存储键名,返回null或data
remove(key, isSessionStorage) 删除key对应的本地数据

isSessionStorage,可选参数。是否存储至sessionStorage,默认值为false。

zxEditor.storage.set('content', {title: '标题', content: '内容'})

通知 notify

zxEditor.on('notifyName', function (callback) {
  // ...
})
  • add-link 点击底部添加链接图标时触发。监听此通知,将阻止编辑器默认处理逻辑执行

    callback: next()

// 自定义添加链接
zxEditor.on('add-link', next => {
  // hybrid模式开发时,此处可以调用原生App提供的接口,访问剪贴板是否有url地址数据
  // 获取到url地址、及其文档title
  // 将链接添加至编辑器中
  next(url, title)
})
  • bottom-modal 底部emoji、text-style模态框显示状态及高度

    callback: {type, show, height}

    type: emoji|text-style

    show: true|false true代表显示,false代表隐藏

    height: number|0

  • debug 消息通知

    callback: message

  • error, 错误异常通知

    callback: {code: 1, msg: 'message'}

  • paste 编辑器中粘贴内容完成通知

    callback: { content: '粘贴的文本内容' }

  • select-picture 点击底部选择图片图标时触发。监听此通知,将阻止编辑器默认处理逻辑执行

方法 methods

// use methodName()
zxEditor.methodName(options)

# addFooterButton(option)

底部工具栏添加按钮,option: Object|Array

// 底部工具栏添加一个“导语”按钮
zxEditor.addFooterButton({
  name: 'summary',
  // 按钮外容器样式名称
  class: 'demo-summary-button',
  // 按钮内i元素样式名
  icon: '',
  // 需要注册的监听事件名
  on: 'summary-button'
})

// 或者
zxEditor.addFooterButton(
  [
    {
      name: 'summary',
      class: 'demo-summary-button',
      icon: '',
      on: 'summary-button'
    }
  ]
)

# addImage(src|base64)

向正文焦点处添加一张图片,支持图片url地址或base64数据

# addMedia(url, type)

向正文焦点处添加图片/音频/视频

图片url地址或base64数据

音频/视频只支持url地址

url: String url地址

type: String, img|audio|video

# filesToBase64(files, opts, callback)

图片文件数据转为base64/blob

参数 类型 说明
files 文件类型 文件数据(伪)数组
opts Object 图片压缩或裁剪参数{width:100,height:100,clip:true}
callback(errorArray, dataArray) errorArray:`null Array, dataArray:null

opts

// 图片压缩、裁剪参数
{
  // 可选,调整图片宽度为100px
  width: 100,
  // 可选,调整图片高度为100px,
  // 该参数不设置,则宽度调整为100px,高度等比缩放
  height: 100,
  // 强制裁剪,包括gif图像
  // 如果为false,将不处理gif图片
  clip: true
}

dataArray

null
// 或者
[
  {
    // 处理完成的dom节点对象
    element: 'canvasElement|imageElement',
    // 文件类型
    type: 'image/png',
    // 处理完成的图片宽度,根据传入的参数定
    width: 100,
    // 处理完成的图片高度
    height: 100,
    // blob数据
    data: 'blob数据',
    // base64数据
    base64: 'base64',
    // 文件大小B
    size: 15455,
    // blob url地址
    url: 'blobUrl',
    // 原始图片数据参数
    rawdata: {}
  }
]

errorArray

null
// 或者
[
  {
    msg: 'message ....'
  }
]

# getBase64Images()

获取正文中所有base64数据的图片,返回一个数组

@return array

  [
    {
      id: 'zxEditor_img_1500001511111',
      base64: '....',
      blob: 'Blob数据,可以用于直接上传,或通过方法toBlobData(base64)转换'
    }
  ]

# getContent(isInnerText)

获取正文内容html。

@params 'isInnerText'可选,默认为false,获取编辑器innerHTML。否则获取innerText。

# insertElm($el, tag)

向正文焦点处添加任意dom元素$el

$el: HTMLElement

tag: String, 可选参数,dom元素标签,如img/div/h2等

// 需要插入的文本内容
let text = '这是通过insertElm()方法插入的文本节点!'
// 创建文本节点
let $textNode = document.createTextNode(text)
// 将文本节点插入至编辑器正文中
zxEditor.insertElm($textNode, 'text')

# on(notifyName, callback)

监听编辑器内部通知。详见"通知Notify"!

例子:

// 自定义选择图片
zxEditor.on('select-picture', _ => {
  // hybrid模式开发时,此处可以调用原生App提供的接口,访问图片文件选择列表
  // 执行图片文件数据获取,
  // 或者获取由原生App处理并上传完成的图片url
  zxEditor.addImage('图片url地址或base64图片数据')
  // 其他操作...
})

# removeHtmlTags(htmlStr)

去除html标签

# removeRedundantCode(content)

移除多余的html代码

<p><br></p>, contenteditable="false", <i class="__remove"></i> ...

# removeSave()

移除本地存储的content内容

# save()

保存编辑器内容

# setContent(innerHTML)

设置编辑器内容,可用于初始化编辑器数据。

# setImageSrc(imgId, imgUrl)

将ID为imgId的图片base64地址,替换为新的imgUrl。需配合getBase64Images()方法使用。

@return boolean

# setKeyboard({ height: 266 })

如果能获取到键盘弹起高度,可以通过该方法设置键盘的高度。

# stopAutoSave()

开启自动保存时有效。停止自动保存编辑数据。

# toBlobData(base64)

将图片base64转换为原始数据类型Blob(),该数据和表单中提交上传的数据同类型,故可以直接上传

@return new Blob() 返回Blob()数据

Copyright and license

Code and documentation copyright 2018. capricorncd. Code released under the MIT License.

About

移动端HTML文档(富文本)编辑器,支持图文混排、引用、大标题、无序列表,字体颜色、加粗、斜体

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 87.9%
  • CSS 10.6%
  • HTML 1.5%