Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

wl-explorer

Package Overview
Dependencies
Maintainers
1
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

wl-explorer

用于vue框架的文件管理器插件,类云盘,网盘。File manager plug-in for vue framework, cloud disk.

  • 0.2.2
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
3
decreased by-85%
Maintainers
1
Weekly downloads
 
Created
Source

wl-explorer

简介

用于vue框架的文件管理器插件,云盘。File manager plug-in for vue framework, cloud disk.

一个基于Vue和ElementUi的文件管理器插件,提供类似某云盘操作台的功能。

此组件较为复杂,并且有些设定可能太贴合原来的项目。初次使用建议clone项目做对照,另有q群回复比较及时:1058847321

提供的功能

  1. 文件夹的编辑,新增,移动,删除,下载

  2. 文件上传、下载、预览,移动

  3. 类似windows文件管理器的文件夹路径搜索,历史记录快捷键

  4. 表格模式、图标模式切换等

在线访问

启动

1. 克隆示例项目
git clone git@github.com:hql7/wl-explorer.git

2. 下载依赖并运行示例项目
npm install
npm run serve

3. 在你的项目上引入wl-explorer
npm i wl-explorer -S
// main.js中
import wlExplorer from "wl-explorer";`
import "wl-explorer/lib/wl-explorer.css"
Vue.use(wlExplorer);

4. 运行你的项目,并对照git@github.com:hql7/wl-explorer.git项目示例

另一个选择

1. 克隆集成了wl-explorer组件的wl-admin后台管理系统模板项目
git clone git@github.com:hql7/wl-admin.git

2. 下载依赖并运行示例项目
npm install
npm run serve

3. 在src/views/ui/explorer文件夹下查看mock数据方案的npm install wlExplorer 示例

快速上手

npm i wl-explorer -S

import wlExplorer from "wl-explorer";`
import "wl-explorer/lib/wl-explorer.css"
Vue.use(wlExplorer);
   <wlExplorer
      ref="wl-explorer-cpt"
      :headerDropdown="headerHandle"
      :columns="file_table_columns"
      :all-path="all_folder_list"
      :is-folder-fn="isFolderFn"
      :folderType="rource_type"
      :data="file_table_data"
      :props="explorer_prop"
      @handleFolder="handleFolder"
      @search="fileSearch"
      @del="fileDel"
      @closeFade="closeOtherLayout(fade)"
    ></wlExplorer>
  内容较多,如下

见github app.vue

文档

Attributes

序号参数说明类型默认值
1headerDropdown头部更多操作自定义菜单,item必须包括字段:name:String菜单名,command:Fn此菜单指令,可选字段disabled:Boolean是否禁用,divided:Boolean是否显示分割线,icon:String图标Array-
2showCheckbox是否显示复选框列Booleantrue
3showIndex是否显示序号列Booleantrue
4showBorder表格是否显示边框Booleantrue
5data列表数据【当前只支持一维数据,每次传入当前文件夹数据,但是组件内会记录并更新已经得到数据的文件夹历史,并不过度依赖请求】Array-
6columns文件列表表头数据Array所有el-table提供的Table-column Attributes
7props配置项(非常重要,尤其是其中path*参数,是使8.allPath生效的关键属性)Object详见下方props
8allPath所有文件路径列表,用于快速访问、移动、上传、新建时Array-
9isFolderFn判断是否文件夹函数function(row)参数是当前行数据,函数应返回Boolean值Function-
10isLockFn判断是否锁定文件夹函数function(row)参数是当前行数据,函数应返回Boolean值Function-
11useUpload是否使用自带上传组件【如需要自定义上传组件,在组件内部写dom即可。不具名solt】Booleantrue
12uploadUrl上传文件地址String-
13uploadReg是否校验上传文件,开启则需要使用uploadRegFuc函数Booleanfalse
14uploadHeaders上传头信息Object-
15uploadOptions上传参数Object-
16uploadLimit最大上传个数Number-
17usePreview是否使用自带预览组件【如需要自定义预览组件,在组件内部写dom即可。不具名solt】Booleantrue
18previewType预览文件类型,'img','video','audio','iframe'(包括txt、html、pdf)Stringimg
19previewOptions文件预览地址或配置项,除video外只需{String}文件链接地址即可,video时见video.js配置项{sources: [{type: "video/mp4",src: ''}]}Object/String-
20splicOptions废弃,合并入props拼接路径配置项,{Splic: 要拼接的字段, Connector: '\', // 连接符; Id: "Id", // 数据源匹配字段;Parents: "Parents", // 所有父节点自增id以上到下排列逗号分隔;IdentityId: "IdentityId", // 当前自增id}Object{ Splic: 'Name', Connector: '\\', Id: "Id", Parents: "Parents", IdentityId: "IdentityId", }

props

序号参数说明默认字段字段值类型
1isFolder用于有布尔值字段表示数据是否文件夹类型的情况,当使用isFolderFn函数时,此参数会被忽略isFolderBoolean
2isLock用于有布尔值字段表示数据是否锁定文件类型的情况,当使用isLockFn函数时,此参数被忽略isLockBoolean
3name用于显示名称列的字段nameString
4suffix用于判断后缀或显示文件类型列的字段suffixString
5match用于设定文件路径输入框自动补全的匹配字段,如下面splic字段值为false时使用nameString
6splic【特殊字段】配置项中只有此参数为字段值,其他均为字段key,即props里必有一个splic参数表示是否需要将路径名拼接为父路径\父路径\当前路径的形式Booleantrue
7pathName路径数据中表示名称的字段nameString
8pathId路径数据中表示id字段idString
9pathPid路径数据中表示parentId的字段pidString
10pathChildren路径数据中表示children字段childrenString
11pathDisabled路径数据中表示禁用字段disabledString
12pathConnector路径父子数据拼接连接符,默认为'''\'String
13pathParents路径数据所有直系祖先节点自增长identityId逗号拼接parentsString
14pathIdentityId路径数据自增长ididentityIdString
15size设置内部组件大小,同elementuimediumString
16rootPidValallPath数据中根节点pid的值,用于退出组装树形数据如[0]-Array

path字段是allPath生效的关键参数,但是比较晦涩难以理解,建议辅以public/data/file-list-all.json数据结构理解,这些path字段只是为了支持在此数据结构下的自定义字段名

Events

序号事件名称说明回调参数
1handleFolder文件夹新增或编辑function(act,type,file)依次为当前选择文件夹、类型edit,add、当前的路径信息
2del删除function(data)依次为要删除的数据
3search获取数据function(path, true)依次为当前路径对象、是否需要更新数据(不需要表示存在历史数据)
4download下载文件或文件夹function(data, cb)依次为选中数据,请求成功后的下载回调函数,使用时将接口设为blob格式,将带请求头的返回值放进cb(res)即可
5move移动function(to, data, load)依次为移动的目标,要移动的数据,防抖变量。在时间的最上部设置load为true可以防抖+loading效果,请求结束需要手动设置为fasle
6closeFade关闭其他弹出框为防止弹出框覆盖,应在接收到此函数时关闭外部页面上其他遮罩性的dom
7showUpload打开上传界面不使用自带上传时调用
8uploadBefore上传前回调function(file, path)依次为上传文件,当前路径对象。可此函数里调整上传接口参数
9upload上传事件function(data, cb)依次为当前路径对象,必须执行的上传回调,最迟应在此函数调整上传参数,后调用cb()上传
10uploadSuccess上传成功回调function(res)依次为接口返回数据,当接口返回列表行实体时,会自动处理逻辑并更新当前数据及历史数据【建议】,当成共不反回数据时,应请求接口更新数据,但是如上传路径非当前路径则历史数据需要手动调用方法更新
11uploadError上传失败回调function(err)依次为错误信息
12preview预览事件function(data, cb)依次为当前选中预览的数据、打开预览组件的回调,应在此处更新预览参数后调用cb()打开预览

Form Methods

方法名说明参数
updateHistoryData更新历史数据,插件有历史时优先使用历史数据,因此非当前路径已经记录历史数据的且数据发生变动时,需手动调用添加function(item, val, update) 依次为:发生数据变动的路径信息Object(至少存在你参数7 props里的pathId字段用于在历史里匹配);变动后的列表数据Array(主要用于新增文件夹或自定义上传时选择了非当前路径时的手动更新,【删除会自动处理】);是否覆盖性更新Boolean(默认为false,当时false时执行数组合并,true时为完整数据覆盖)

Slot

序号name说明
1header-btn头部自定义操作按钮,位置在更多操作按钮前
2header-dropdown头部更多操作slot,建议使用参数1的形式
3table-column-top自定义列,位置在参数6前,建议使用参数6的形式,可以formatter自定义dom
4table-column-bottom自定义列,位置在参数6后,建议使用参数6的形式,可以formatter自定义dom
5main在路径操作栏下的列表区
6-不具名slot,可以写任何dom模块

版本记录

0.2.2 props内增加rootPidVal字段,用于自定义allPath数据根节点pid的值

0.2.1 修复allPath不传时的报错

0.2.0 修复平铺模式checkbox选中仍隐藏问题

0.1.8 修复上传文件的路径问题

0.1.7 修复文件路径拼接逻辑未采用splicOptions参数的错误,并将splicOptions废弃,合并入props,所有带path前缀的字段

0.1.6 修改debounce为throttle

0.1.5 增加size参数管理组件内小组件大小

0.1.4 修复图标模式,名称字段未使用props配置的错误

0.1.2 修复部分未按照props设置而写死字段的代码;修复updateHistoryData手动更新历史记录函数缺失问题

0.1.1 优化内置预览组件参数缺省时的错误;文档增加方法的说明;优化主slot在列表区的错误,并在列表区增加name为main的slot;

0.1.0 wl-explorer第一个版本发布

0.0.1 初次发布,部分功能未解耦,待续

待续

  1. 优化预览组件

Keywords

FAQs

Package last updated on 03 Dec 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc