当前位置: 首页 > news >正文

websheet之 编辑器

一、默认编辑器

         该单元格编辑器是控件自带的编辑器,用户不需要指定。

二、下拉选择

         该单元格编辑器是控件自带的编辑器的一种。该控件需要你指定下拉的数据源。在下面的例子中,我们给C3和C6单元格指定了币种的下拉选择编辑器。参数见:六、 参数说明。

/*** 币种下拉*/let wsheet = new websheet('HTML', yourElement);/*** 第一步 获取激活sheet*/let activeSheet = wsheet.ActiveSheet();/*** 第二步 币种下拉控件,并注册*/const cny = document.createElement('option');cny.value = 'CNY';cny.textContent = 'CNY-人民币';const usd = document.createElement('option');usd.value = 'USD';usd.textContent = 'USD-美元';const eur = document.createElement('option');eur.value = 'EUR';eur.textContent = 'EUR-欧元';let optionsBZ= [cny, usd, eur];activeSheet.setCellEditor('C3', websheet.Model.SelectCell, {data:optionsBZ,bextend:true});activeSheet.setCellEditor('C6', websheet.Model.SelectCell, {data:optionsBZ,bextend:true});/*** 第三步   重新绘制表格*/activeSheet.setColWidth(1, 160);activeSheet.setColWidth(2, 160);activeSheet.setColWidth(3, 160);activeSheet.setColWidth(4, 160);activeSheet.setColWidth(5, 160);activeSheet.WorkFormula(); //重建公式activeSheet.cacl();//公式计算wsheet.BuildSheet();wsheet.Draw();

         结果如下图:

在这里插入图片描述

在线代码
{.is-success}

三、日期时间编辑器

         websheet控件使用小巧flatpickr控件来实现日期时间编辑器,版本是:4.6.13。

3.1 默认日期编辑器

    activeSheet.SetCellValue('B3','2025-02-28');activeSheet.setCellEditor('B3', websheet.Model.DatePickCell);

3.2 月份

    activeSheet.SetCellValue('B3','2025-02-28');activeSheet.setCellEditor('B3', websheet.Model.DatePickCell);

3.3 日期多选

    activeSheet.SetCellValue('B3','2025-02-28');activeSheet.setCellEditor('B3', websheet.Model.DatePickCell);

3.4 日期时间

    activeSheet.SetCellValue('B3','2025-02-28');activeSheet.setCellEditor('B3', websheet.Model.DatePickCell);

3.5 时间

   activeSheet.SetCellValue('B3','2025-02-28');activeSheet.setCellEditor('B3', websheet.Model.DatePickCell);

         其设置可以参考flatpickr的官方网站。

         效果图如下:

在这里插入图片描述

在线代码
{.is-success}

四、进度条

         该进度条展示控件是自带的编辑器的一种, 该控件根据单元格的绘制完成比例。完整代码如下:

    /*** 第一步 获取激活sheet*/let activeSheet = wsheet.ActiveSheet();activeSheet.SetCellValue('A3','Progress控件'); /*** 第二步 一个下进度条控件,并注册*/let redoptions={isVertical:false,background:  '#eee',foreground:  'red',textColor:  '#333',};activeSheet.SetCellValue('B3',0.01);//设置完成度activeSheet.setCellEditor('B3', websheet.Model.ProgressCell,redoptions);let yeoptions={isVertical:false,background:  '#eee',foreground:  'yellow',textColor:  '#333',};activeSheet.SetCellValue('B4',0.50);//设置完成度 activeSheet.setCellEditor('B4', websheet.Model.ProgressCell, yeoptions);activeSheet.SetCellValue('B5',1);//设置完成度 activeSheet.setCellEditor('B5', websheet.Model.ProgressCell);activeSheet.SetCellValue('B6','Aab');//设置完成度activeSheet.setCellEditor('B6', websheet.Model.ProgressCell);/*** 第三步   重新绘制表格*/activeSheet.setColWidth(1, 160);activeSheet.setColWidth(2, 260);activeSheet.setColWidth(3, 160);activeSheet.setColWidth(4, 160);activeSheet.setColWidth(5, 160);activeSheet.WorkFormula(); //重建公式activeSheet.cacl();//公式计算wsheet.BuildSheet();wsheet.Draw();

在这里插入图片描述

在线代码
{.is-success}

         上下文参数如下:

参数说明是否必须
background背景颜色,例如’#eee’
foreground前景颜色,‘red’
textColor文本颜色

五、自动选择代码

         该编辑器可以根据输入自动筛选匹配的数据,可以通过鼠标或上下按键选择展示的内容,代码如下:

    /*** 第一步 获取激活sheet*/let activeSheet = wsheet.ActiveSheet();/*** 第二步 定义数据源,设置单元格编辑器为websheet.Model.CodeSelector*/const codeData = [{ code: "B01", description: "苹果" },{ code: "B02", description: "香蕉" },{ code: "B03", description: "橙子" },{ code: "B04", description: "西瓜" },{ code: "B05", description: "葡萄" },{ code: "A01", description: "电视机" },{ code: "A02", description: "冰箱" },{ code: "A03", description: "洗衣机" },{ code: "C01", description: "笔记本电脑" },{ code: "C02", description: "手机" },{ code: "C03", description: "笔记本电脑1" },{ code: "C04", description: "手机1" }];activeSheet.setCellEditor('C1:C10', websheet.Model.CodeSelector, {showdata:codeData,placeholder:'选择代码',bextend:true});activeSheet.setColWidth(3, 250)/*** 第三步   重新绘制表格*/wsheet.BuildSheet();wsheet.Draw();

在这里插入图片描述

在线代码
{.is-success}

         上下文参数如下:

参数说明是否必须
showdata需要展示的数组,对象格式“{code: “B01”, description: “苹果” }”
placeholder提示词,默认‘代码选择’
bextend名称是否填充 ,默认’false’

六、 参数说明

         setCellEditor的参数说明如下:

参数说明是否必须
range单元格地址,例如‘A1’
widget视图控件,例如websheet.Model.DatePickCell控件
contex上下文,例如展示币种控件需要币种的数据源

七、待开发的控件

  1. Radio 单选框
  2. Checkbox 多选框
  3. Switch 开关
  4. Slider 滑块

八、自定义编辑器

         如果你有自己编辑控件和展示内容的需求,可以参考自定义展示控件。

相关文章:

  • 开发体育直播系统内容与用户管理机制技术实现方案
  • 【玩泰山派】7、玩linux桌面环境xfce - (4)使用gstreamer
  • 3.4 Spring Boot异常处理
  • 酷狗音乐安卓版K歌功能与音效优化体验测评
  • 基于vue框架的电信用户业务管理系统的设计与实现8ly70(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • 容器化实现基于的技术
  • C++----模拟实现string
  • 《Java编程思想》读书笔记:第十章 内部类
  • IMX675-AAQR-C 索尼图像传感器 属于索尼 Starvis 2 系列,主打 高灵敏度、低噪声,适用于工业检测、安防监控、机器视觉等场景 提供数据手册
  • 从零开始学Python游戏编程40-碰撞处理2
  • fps项目总结:生成武器子弹丧尸攻击
  • pyinstaller打包paddleocr发生错误解决
  • 【5】GD32 基础通信外设:USART、I2C、SPI
  • 正则表达式三剑客之——awk命令
  • OCR(Optical Character Recognition),光学字符识别
  • 使用 Python 项目管理工具 uv 快速创建 MCP 服务(Cherry Studio、Trae 添加 MCP 服务)
  • 通道降维方式
  • 一款好的私有云产品推荐——优刻得私有云(UCloudStack Pro)产品白皮书
  • 单机无穷大系统暂态稳定性仿真Matlab模型
  • 数据库-子查询、关联查询 和 TCL 语言
  • “爱泼斯坦案”关键证人弗吉尼亚·朱弗雷自杀身亡
  • 泰山景区管委会:未经审核同意不得擅自举办竞速类登山活动
  • 经济日报金观平:充分发挥增量政策的经济牵引力
  • 铜钴巨头洛阳钼业一季度净利润同比大增九成,最新宣布首度进军黄金矿产
  • 科克托是说真话的骗子,而毕加索是一言不发、让大家去猜的人
  • 上海车展的“老头乐”,又升级了