Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kaola-fed/octoparse
octoparse是一款html解析转换工具。可以将html解析成对象并转换成其他文本。支持html转微信小程序、支付宝小程序与百度小程序。
https://github.com/kaola-fed/octoparse
html octoparse parser
Last synced: about 2 months ago
JSON representation
octoparse是一款html解析转换工具。可以将html解析成对象并转换成其他文本。支持html转微信小程序、支付宝小程序与百度小程序。
- Host: GitHub
- URL: https://github.com/kaola-fed/octoparse
- Owner: kaola-fed
- License: mit
- Created: 2018-08-24T01:10:02.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T19:14:20.000Z (about 2 years ago)
- Last Synced: 2024-11-13T04:52:19.219Z (about 2 months ago)
- Topics: html, octoparse, parser
- Language: JavaScript
- Homepage:
- Size: 5.04 MB
- Stars: 45
- Watchers: 8
- Forks: 13
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## octoparse
**octoparse**是一款html解析转换工具。可以将html解析成对象并转换成其他文本。支持html转微信小程序、支付宝小程序与百度小程序。
## 快速开始
### 下载
```html
npm install octoparse
```### 直接使用
```html
import octoparse from 'octoparse'
let htmlStr =
``;
test
let res = octoparse.htmlParse(htmlStr)
```### 在vue中以插件方式使用
```html
import Vue from 'vue'
import octoparse from 'octoparse'
Vue.use(octoparse)
let htmlStr =
``;
test
let res = Vue.$htmlParse(htmlStr)
```
### 在小程序中使用
1、在小程序模板中引入octoparse模板* 此处的data的key需要为nodes以便和octoparse小程序模板的入口模板保持一致
* 此处的例子为微信小程序,支付宝小程序的使用方式基本相同,注意引用的模板为platform/alipay/index.axml
```html
```
2、 在page中挂载数据
```html
import octoparse from 'octoparse'
Page({
...
onLoad: function(){
let htmlStr =
``;
test
let res = octoparse.htmlParse(htmlStr)
this.setData({
htmlData: res
})
}
...
})```
### 在Megola中使用[Megola 基于Vue的跨平台小程序开发框架](https://github.com/kaola-fed/megalo)
1、在webpack中配置挂载小程序模板
```html
module.exports = {
...
target: createMegaloTarget( {
compiler: Object.assign( compiler, {}),
platform: 'wechat',
htmlParse: {
templateName: 'octoParse',
src: resolve('node_modules/octoparse/lib/platform/wechat')
}
}),
...
}```
2、在vue上挂载octoparse
```html
import Vue from 'vue'
import octoparse from 'octoparse'
Vue.use(octoparse)
```
3、在页面中使用
```html
data(){
return {
vhtml:``test
}
}
```### 基本使用
将html转换为树结构
```html
let htmlStr =
``;
test
let res = octoparse.htmlParse(htmlStr)```
### 节点预处理
使用visitors方法对解析的html节点进行处理。
例如:为所有的img图片加上display:block样式去除连续图片中间的缝隙
```html
let options = {
visitors: {
img(node){
node.styleStr = 'display:block';
}
}
}
let htmlStr =
`
`;
let res = octoparse.htmlParse(htmlStr, options)
```
#### 节点属性释义| 属性名 | 含义 | 注释 |
| ------ | ------ | ------ |
| node | 节点类型 | |
| tag | 节点标签名 | |
| index | 节点在节点树中的序列号 | |
| attr | 属性键值对 | |
| classStr | class字符串 | 在模板中使用该属性使class生效|
| styleStr | style字符串 | 在模板中使用该属性使style生效 |
| nodes | 子节点数组 | |参考: [访问者模式](https://zh.wikipedia.org/wiki/%E8%AE%BF%E9%97%AE%E8%80%85%E6%A8%A1%E5%BC%8F)
### 使用插件
支持插件,例如:
```html
import removeBackground from '../../lib/plugins/removeBackground';
let options = {
plugins: [removeBackground],
}
let htmlStr =
``;
test
let res = octoparse.htmlParse(htmlStr, options)
```### 本地开发
* git clone https://github.com/kaola-fed/octoparse.git
* cd octoparse
* npm i
* npm install gulp -g (安装一下gulp)
* npm run build
* gulp (因为小程序不允许引用根目录以外的文件,所以这里跑一下gulp任务将模板拷贝到小程序demo的目录下面)## 灵感来源
名字来源于游戏 `octopath tarveler`。项目启发自 `wxParse`。