开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1305|回复: 50
收起左侧

[易语言成品模块] SciterUI模块 V1.0 - 让易语言用上 HTML/CSS/JS 开发现代化界面

[复制链接]
结帖率:77% (10/13)
发表于 2025-12-11 13:48:30 | 显示全部楼层 |阅读模式   泰国
分享例程
界面截图:
备注说明: -
本帖最后由 chungbin 于 2025-12-11 17:09 编辑

# [已开源] SciterUI模块 V1.0 - 让易语言用上 HTML/CSS/JS 开发现代化界面 (支持双向交互/GPU加速)

源码地址:[开源] SciterUI模块 V1.0 - 让易语言用上 HTML/CSS/JS 开发现代化...
https://bbs.ijingyi.com/forum.php?mod=viewthread&tid=14869170
(出处: 精易论坛)



**软件名称**:SciterUI 模块
**软件版本**:V1.0
**编译环境**:易语言 5.93 / Visual Studio 2026 (DLL)
**开源协议**:MIT / Sciter License


---

前言
还在为易语言原生界面丑陋、ExDui/ExUi 学习成本高而烦恼吗?
**Sciter** 是一个轻量级、可嵌入的 HTML/CSS/脚本 引擎,专为桌面 UI 设计。它支持 GPU 加速,渲染速度极快,且体积小巧(老版本DLL 仅 几 MB,新版本也才 10 几 MB)。
本模块通过封装 `SciterWrapper.dll`,解决了易语言无法直接调用 Sciter 复杂函数指针的问题,让易语言也能轻松使用 Web 前端技术开发界面!


部分界面预览
PixPin_2025-12-03_12-29-24.png
PixPin_2025-12-04_17-03-49.png

核心功能 (V1.0)

1.  **极速渲染**:基于 Sciter.JS 引擎,支持 ES6、CSS3、Flex/Grid 布局,GPU 硬件加速。
2.  **双向交互**:
    *   **易语言 -> JS**:支持调用 JS 函数,获取返回值(支持 整数、小数、文本)。
    *   **JS -> 易语言**:支持注册回调函数,JS 中直接调用 `__eplCall('函数名', 参数...)` 触发易语言子程序。
3.  **无边框窗口**:内置完美的无边框窗口方案,支持拖拽移动、八方向缩放、最大化/还原动画,无需处理复杂的 Windows 消息。
4.  **DOM 操作**:提供丰富的 API 操作 HTML 元素(获取/设置属性、样式、文本、显示/隐藏等)。
5.  **中文友好**:底层自动处理 ANSI (GBK) 与 Unicode (UTF-16) 转换,易语言端直接操作文本,无需乱码烦恼。
6.  **调试支持**:支持连接 Sciter Inspector 进行类似 Chrome 开发者工具的 UI 调试。


###  更新日志 (V1.0)
*   [新增] 完整的 JS 回调机制 (`Sciter_注册回调`),修复了参数传递的类型错误。
*   [新增] `Sciter_取参数文本` 等辅助命令,方便在回调中解析 JS 传来的参数。
*   [优化] 修复了 DLL 导出函数名修饰问题,调用更稳定。
*   [优化] 增加 `Sciter_快速创建应用` 命令,一行代码启动 UI。


代码演示

1. 易语言端代码
```e
  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
变量名类 型数组备 注
hWindow整数型  

子程序名返回值类型公开备 注
_启动子程序整数型 请在模块中引用 SciterUI模块

' 1. 初始化引擎
Sciter_初始化 ()
' 2. 创建无边框窗口 (1024x600)
hWindow = Sciter_创建无边框窗口 (1024, 600)

' 3. 注册 JS 回调 (让 JS 能调用易语言)
Sciter_注册回调 (&JS回调处理, hWindow)
' 4. 加载 UI 文件
Sciter_加载HTML文件 (hWindow, 取运行目录 () + "\ui\index.html")
' 5. 显示并运行
Sciter_显示窗口 (hWindow)
Sciter_运行 ()

返回 (0)
子程序名返回值类型公开备 注
JS回调处理逻辑型 
参数名类 型参考可空数组备 注
方法名文本型
参数个数整数型
参数数组整数型
返回值整数型
变量名类 型静态数组备 注
msg文本型 
' JS 调用示例: Window.this.xcall("msgbox", "Hello from JS!");
如果真 (方法名 = "msgbox")
msg = Sciter_取参数文本 (参数数组, 0)
信息框 ("JS 传来的消息: " + msg, 0, "提示")

返回 ()

```

2. HTML/JS 端代码
```html

[HTML] 纯文本查看 复制代码
<html>
<head>
    <style>
        body { margin: 0; background: #333; color: #fff; font-family: "Microsoft YaHei"; }
        .header { height: 30px; background: #222; flow: horizontal; vertical-align: middle; padding: 0 10px; }
        button { behavior: clickable; cursor: pointer; }
    </style>
    <script>
        // 绑定按钮点击事件
        document.on("click", "#btn-test", function() {
            // 调用易语言函数
            Window.this.xcall("msgbox", "我是网页中的按钮!");
        });
    </script>
</head>
<body>
    <div class="header" role="window-caption">
        <div>Sciter UI 演示</div>
    </div>
    <div style="padding: 20px;">
        <h1>Hello Sciter!</h1>
        <button id="btn-test">点击在易语言中处理</button>
    </div>
</body>
</html>

```

必须文件
1.  `SciterUI模块V1.0.ec` - 易语言模块
2.  `SciterWrapper.dll` - 接口封装库 【已开源】
3.  `sciter.dll` - 官方引擎文件 【未打包,可在官网下载】


下载地址

游客,如果您要查看本帖隐藏内容请回复

源码下载地址:
游客,如果您要查看本帖隐藏内容请回复

所需的必须文件:
游客,如果您要查看本帖隐藏内容请回复


点击链接加入群聊【SciterUI讨论学习群】:https://qm.qq.com/q/5qkP3rEb4I

**致谢**:感谢 Sciter 作者 Andrew Fedoniouk 提供如此优秀的引擎。
**声明**:本模块完全开源,欢迎大佬们一起完善!





补充内容 (2025-12-13 09:49):
SciterUI模块 V1.1 - 支持透明异形窗口!
https://bbs.ijingyi.com/forum.php?mod=viewthread&tid=14869222
(出处: 精易论坛)

点评

这个太强了,必须感谢,学习   山东省济南市  发表于 2025-12-11 16:01

评分

参与人数 4好评 +3 精币 +8 收起 理由
素顏じ亦傾國ジ + 1 用HTML+CSS+JS做界面也太好看 了吧
yuan71058 + 1 + 3 这个太强了,必须感谢,学习
pptk + 1 + 2 新技能已get√
Daen + 1 + 2 这个太强了,必须感谢,学习

查看全部评分


友情提醒:请选择可信度高的模块,勿用未知模块,防止小人在模块内加入木马程序。【发现问题模块请到站务投诉】。

本帖被以下淘专辑推荐:

  • · 收藏|主题: 336, 订阅: 6
结帖率:0% (0/1)

签到天数: 6 天

发表于 昨天 04:14 | 显示全部楼层   河北省石家庄市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:33% (4/12)

签到天数: 22 天

发表于 6 天前 | 显示全部楼层   海南省海口市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:77% (10/13)

签到天数: 19 天

 楼主| 发表于 6 天前 | 显示全部楼层   泰国
hsvs4 发表于 2025-12-18 10:45
终于来了 之前K大弄过 不过他不更新了   等了好几年

我就是自己想用结果论坛没有,也只搜到一个稍微很简陋的演示的旧版的,所以我自己弄了这个
回复 支持 反对

使用道具 举报

结帖率:100% (4/4)

签到天数: 23 天

发表于 6 天前 | 显示全部楼层   山东省淄博市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)

签到天数: 19 天

发表于 7 天前 | 显示全部楼层   广西壮族自治区贵港市
终于来了 之前K大弄过 不过他不更新了   等了好几年
回复 支持 反对

使用道具 举报

结帖率:100% (5/5)

签到天数: 24 天

发表于 2025-12-12 20:45:21 | 显示全部楼层   陕西省西安市
这个太强了,必须感谢,学习
回复 支持 反对

使用道具 举报

签到天数: 5 天

发表于 2025-12-12 20:34:43 | 显示全部楼层   广东省东莞市
好东西啊,谢谢楼主分享
回复 支持 反对

使用道具 举报

结帖率:89% (8/9)

签到天数: 3 天

发表于 2025-12-12 18:46:03 | 显示全部楼层   江西省赣州市
感谢分享~~~~~~
回复 支持 反对

使用道具 举报

签到天数: 25 天

发表于 2025-12-12 17:15:53 | 显示全部楼层   湖北省鄂州市
感谢分享
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表