LinuxDo 新帖推送
185 subscribers
253K photos
315K links
Download Telegram
标题: 推荐我自用的一套翻译搭配
作者: #yanmoshen
板块: #开发调优
编号: 1039168
帖子: https://linux.do/t/topic/1039168
时间: 2025-10-13 11:36:03
摘要:
现在很多ai翻译好用是肯定的,但是api都十分昂贵,就算是会员制的模式,每个月也是一笔开销。虽然确实有很多免费模型,比如公益站,但是翻译效果不算理想。有没有折中一点的模型,翻译效果中等水平,而且价格很低?Qwen系列搭配沉浸式翻译和Stranslate是个不错的选择,新人登录送100万token



bailian.console.aliyun.com





大模型服务平台百炼控制台

百炼控制台是阿里云大模型服务平台,提供AI模型训练、部署、推理一站式服务,支持多种大模型框架,助力企业快速构建AI应用。












在上面链接登录后,点击右上角,选择最上面带箭头的账号中心,去阿里云实名认证,按照提示操作就行。

完成实名后,回到最初的网站,选择上边导航栏的模型服务,点击左下角密钥管理创建个人密钥,然后复制密钥。

创建好密钥,点击模型广场,选择你想要用的模型(注:100万token指的是每个模型都有这么多,而不是全部模型共享),比如用Qwen-MT-plus为例。

可以把免费额度用完即停这个开关打开.

然后打开沉浸式翻译的设置界面,点击添加自定义翻译服务。

选择qwen MT

把api粘贴指定位置,然后选择qwen-mt-plus模型。

点击右上角测试一下,按道理来说是能用的,如果不行看看有没有漏掉之前的步骤。
同理,可以将api用在Stranslate(解决浏览器外的翻译)中https://stranslate.zggsong.com/
安装后打开设置(不小心关闭可以在右下角显示隐藏的图标找到,右键后点击偏好设置),按照图示点击+号就可以添加模型,应该可以正常使用,建议看看快捷键,了解基本功能。

都看到最后了,我就再发一个每天免费1000次调用的链接(不是1000token),完全足够每日翻译消耗。



modelscope.cn





ModelScope 魔搭社区

Model
标题: 有没有哪位大佬能推荐一下好的头戴式耳机嘛,选二耳机迷茫了
作者: #snowx
板块: #搞七捻三
编号: 1039172
帖子: https://linux.do/t/topic/1039172
时间: 2025-10-13 11:37:17
摘要:
最近看了好多的耳机,品控的也不大好,性价比也不是很高,球球了
标题: 求推荐看动漫的类似腾讯视频的资源
作者: #江枫
板块: #搞七捻三
编号: 1039175
帖子: https://linux.do/t/topic/1039175
时间: 2025-10-13 11:37:56
摘要:
最近想看些动漫发现腾讯视频vip都不行了,需要给钱点映加更太坑人了,看超前还要svip,奇葩的是vip还有广告,不想再用这玩意了,佬们有没有资源可以推荐一下。
标题: 重磅福利加倍(国内镜像Claude 普号14天)免费赠送100个名额,另外抽5名7天Claude pro,看谁会是幸运之子
作者: #GptAi
板块: #福利羊毛
编号: 1039177
帖子: https://linux.do/t/topic/1039177
时间: 2025-10-13 11:38:31
摘要:
重磅好消息!上次没领到Claude的朋友们看过来!
都知道上次福利只有1天,还撞上国庆假期,根本来不及深度体验… 而且最近Claude官网还涨价了!
但!我们为大家争取到了超级加码福利!
主力福利:Claude 普通账号,整整30天有效期!(名额100个)

喜彩蛋:还将抽选5名“天选之子”,直接送上Claude pro+MAX 体验7天!
官网涨价,我们免费送!就为让大家玩得尽兴~
机会有限,快进群领取吧!

特别声明:
官方链接:https://claudechn.com/pastel#/register?i=o4v2Q
活动时间:
开始时间:发帖时间
结束时间:24小时
参与方式:
门槛:任意回复
抽奖规则:
每位用户仅允许参与一次。
使用 LINUX DO 抽奖程序随机抽取中奖者。
标题: 问问各位佬,闲置的光猫可以干什么?
作者: #Cheems
板块: #搞七捻三
编号: 1039187
帖子: https://linux.do/t/topic/1039187
时间: 2025-10-13 11:42:49
摘要:
问问各位佬,闲置的光猫可以干什么?
手里有三个电信的,一个移动的……
有什么好的玩法吗?
标题: 【自荐】极简的导航网站,回归导航网站的本质
作者: #Xre3ty
板块: #资源荟萃
编号: 1039195
帖子: https://linux.do/t/topic/1039195
时间: 2025-10-13 11:44:44
摘要:
Hcqi.top 由本人在 2024 年 7 月 创建,特点如下:

无需注册登录,无限制浏览
人工精选收录,不定期检查链接
无任何 Cookie 跟踪,保护隐私
无任何广告,尽情访问
无多余跳转,点击直达网站
极简界面,无多余干扰元素
每天会自动随机刷新网站排序,趣味无穷
纯前端网站,轻快加载
标题: droid没了?接在kilo似乎还能蹬
作者: #自立
板块: #搞七捻三
编号: 1039199
帖子: https://linux.do/t/topic/1039199
时间: 2025-10-13 11:45:46
摘要:
droid的key放cc里目前应该是用不了了(尝试了一下),但是放在kilo里还是可以蹬的 ,虽然我的赠金全没了,但是看在还能用的份上原谅一下droid吧。
4.5不能用,其他似乎正常!
标题: idea的一个问题
作者: #Ningx
板块: #开发调优
编号: 1039201
帖子: https://linux.do/t/topic/1039201
时间: 2025-10-13 11:46:10
摘要:
执行如下操作

结果只跳出了这个窗口

佬友们有遇到类似的问题吗
标题: 分享一点被Gemini无情打击的对话
作者: #yjq
板块: #开发调优
编号: 1039205
帖子: https://linux.do/t/topic/1039205
时间: 2025-10-13 11:48:16
摘要:
前言
我是一个野生运维,机缘巧合之下 学了一点代码皮毛,然后就开始了疯狂输出,由于系统有些硬伤,找Gemini诊断诊断,然后发现我果然是野生的。
根据以上所有的聊天内容和代码复盘一下 当前这个支持后端定义表单配置和联动规则的通用表单系统中设计和实现上有哪些问题和改进方向

好的,根据我们之前所有的聊天内容和代码分析,我们来对这个功能强大的、支持后端驱动的通用表单系统进行一次全面的复盘,总结其在设计与实现上存在的核心问题以及明确的改进方向。
系统现状与核心能力
该系统设计的初衷非常强大:通过后端返回的JSON配置来动态渲染表单、定义字段类型、以及处理字段之间复杂的级联联动规则。这使得前端能够快速适应业务变化,而无需修改代码。
然而,随着功能(特别是map_list、tree-data等复杂嵌套组件)的演进,初期的架构设计遇到了一些瓶颈,导致实现变得复杂且难以维护。

一、核心问题总结
经过深入探讨,我们识别出当前架构中存在的三大核心问题:
1. 职责边界不清与紧密耦合 (Unclear Responsibilities & Tight Coupling)

问题表现:核心联动逻辑 get_dependency_data_v2 被放置在了一个全局单例服务 MySharedService 中。由于服务本身是无状态的,为了执行特定组件的逻辑,必须将组件的整个上下文实例 (vm) 作为参数传递。
根本原因:这是一种典型的“辅助类”反模式,它破坏了组件的封装性。服务层代码被迫了解并操作组件的内部实现(如 vm.project),导致服务与组件之间产生了高度耦合。
负面影响:代码难以理解、追踪和测试。任何对组件内部的修改都可能影响到这个全局服务。

2. 状态管理模型混乱 (Chaotic State Management)
这是最关键的问题,体现在三个层面:

A. 缺乏实例状态隔离:在 map_list 或 tree-data 这类数组/树形表单中,所有子组件实例的配置 (input) 都引用自同一个父级模板对象。当一个联动事件试图修改某个子组件的配置属性(如 readonly、show)时,会错误地修改所有兄弟组件的配置,因为它们共享同一个内存地址。
B. 动态配置持久性缺失:当一个联动(如父表单的开关)统一修改了数组子表单中所有行的某个属性后,如果用户新增一行,新行会根据原始的、未被修改的模板来创建,导致新行无法继承之前已生效的动态变更,造成状态不一致。
C. 初始化与动态更新逻辑混淆:在加载编辑数据时,系统通过 setInputSetting 方法来执行一系列“联动指令”以达到表单的初始状态。这种命令式的初始化方式,复用了本应处理用户动态交互的事件系统,使得表单加载的逻辑不够直接和声明式,增加了调试难度。

3. 事件寻址机制不精确 (Imprecise Event Addressing)

问题表现:在 OpsTreeDataComponent 这样的递归组件中,由于配置模板被深层复制,导致同一个配置ID (input.id) 会在数据树的不同层级中出现多次。
根本原因:当前的事件系统主要依赖 targetInputId 来寻址。当ID不再唯一时,一个联动事件会被多个不相关的组件实例错误地消费,无法实现对树中特定节点的精确定向联动。


二、架构改进方向与实施策略
针对以上问题,我们已经设计出了一套完整且协同工作的改进方案,旨在构建一个更清晰、健壮和可维护的架构。
1. 组件职责回归与服务解耦

实施策略:将核心联动逻辑 get_dependency_data_v2 从 MySharedService 迁移到 OpsWidgetComponentV3 组件内部。
收益:

消除 vm 传递:组件方法内可通过 this 直接访问自身状态,代码更简洁、内聚。
职责明确:组件自己负责获取自己的数据依赖,符合高内聚、低耦合的设计原则。
服务净化:MySharedService 和 FormSettingDataService 回归其作为纯粹的服务/事件总线的角色。



2. 建立清晰、分层的状态管理模型
这是本次重构的核心,将混乱的状态管理拆分为三个清晰的层次:


A. 组件实例状态 (Component Instance State)

策略:在 OpsWidgetComponentV3 的 ngOnChanges 中,对传入的 @Input() input 进行深拷贝,赋值给组件内部的 localInput 属性。
解决:彻底解决数组/树形组件中因共享引用导致的状态污染问题,确保每个组件实例的状态完全隔离。



B. 表单级动态覆盖状态 (Form-Level Dynamic Override State)

策略:在 FormSettingDataService 中引入一个 dynamicSettingOverrides 对象,专门用于持久化那些需要作用于所有(包括未来新增的)同类子组件的广播式配置变更。
解决:解决了动态配置持久性缺失的问题。当新增子表单行时,会从这个“覆盖层”中读取并应用所有相关规则,保证新旧组件状态一致。



C. 声明式的初始状态加载

策略:调整后端接口,在返回编辑数据时,除了表单值,还直接返回一个初始状态的 initialOverrides 对象。FormSettingDataService 提供一个 loadInitialOverrides 方法在表单加载时一次性设置好所有初始UI状态。
解决:将初始化与动态更新彻底分离。加载逻辑变得声明式(直接设置状态),WidgetChangeSubject 也回归其作为纯粹动态事件总线的职责,系统行为更可预测。



3. 优化事件系统,实现精确寻址

策略:在 OpsWidgetComponentV3 的 checkUpdate 方法中,强化事件的消费逻辑,区分定向联动和广播联动。

定向联动:要求事件的 targetInputId 和 opsDataIdForEditDependency(数据上下文ID)同时匹配组件自身的ID和数据上下文,实现对树中特定节点的精确打击。
广播联动:利用上述的“动态覆盖层”机制来处理。


解决:解决了在递归树等复杂结构中,因配置ID复用导致的事件寻址不精确问题。

总结:新架构的核心优势
通过以上系统性的重构,该通用表单系统将从一个功能强大但实现复杂的“战术级”产品,演进为一个架构清晰、逻辑稳健的“战略级”解决方案,其核心优势体现在:

高内聚,低耦合:组件自我管理,服务角色单一,系统各部分职责分明。
清晰的状态分层:彻底厘清了实例状态、模板状态和初始状态,让状态管理不再混乱。
健壮性与可预测性:无论是处理复杂嵌套结构还是动态增删,系统行为都变得明确且可预测。
易于维护与扩展:当需要支持新的联动类型或组件时,可以在清晰的架构上进行扩展,而不会牵一发而动全身。

review一下代码,给点聊天中没有关注到的问题和架构优化方向

好的,我们已经深入探讨了联动和状态管理的核心机制。现在,让我们跳出之前的讨论,从一个更宏观的视角来复盘整个代码库,并关注一些之前没有详细讨论过的问题和架构优化方向。
综合评估
这是一个功能非常强大的动态表单系统,其核心的“后端驱动UI”思想极具价值。代码中已经体现了很多优秀实践,例如动态组件渲染 (WidgetRegistry) 和 OnPush 变更检测策略。
然而,随着系统复杂度的提升,一些“代码债”和架构上的模糊地带也开始显现。以下是几个关键的改进方向:

1. 架构设计 (Architecture & Design)
问题一:上帝服务 (MySharedService) 与职责划分
当前 MySharedService 承担了过多的职责,成为了一个典型的“上帝对象 (God Object)”。它既管理着全局数据 (data, globData),又负责UI布局 (setLayoutHeight),同时还是一个巨大的事件总线 (拥有十几个Subject),甚至还包含了具体的业务逻辑(openMenu, getFormData)。

影响:这严重违反了单一职责原则 (SRP)。代码高度集中,导致任何微小的修改都可能影响到不相关的功能,使得服务难以维护、测试和理解。
优化方向:服务拆分。

LayoutService: 专门负责管理页面布局、窗口大小变化 (resizeObservable$) 和日志区域的显隐。
NavigationService: 负责路由、菜单和标签页的管理 (openMenu, closeTab, routeTabs)。
AppStateService: 负责存储真正的全局应用状态,如用户信息、全局变量 (ops_vars) 等。
FormLifecycleService: 专门负责表单数据的获取和提交流程 (getFormData)。
EventBusService: 可以保留一个轻量级的事件总线,但应明确其用途仅限于跨模块的低耦合通信,而不是承载所有事件。



问题二:组件注册机制不够自动化
ops-widget-v3.ts 中使用了 WidgetRegistry 服务来动态创建组件,这是一个非常好的模式。但代码中没有展示组件是如何被注册到 WidgetRegist
标题: 期待gemini 3 pro
作者: #hjj194
板块: #搞七捻三
编号: 1039210
帖子: https://linux.do/t/topic/1039210
时间: 2025-10-13 11:49:19
摘要:
快端上来罢
标题: 元宝还能这样用?有点离谱了!
作者: #F-Droid
板块: #搞七捻三
编号: 1039220
帖子: https://linux.do/t/topic/1039220
时间: 2025-10-13 11:53:45
摘要:
在微信视频号评论区下面直接@元宝,真的是一个骚操作!
标题: 手搓手教你 彩色回复card
作者: #王源
板块: #搞七捻三
编号: 1039221
帖子: https://linux.do/t/topic/1039221
时间: 2025-10-13 11:53:52
摘要:
‘ >[!warning] 内容 ’
‘ >[!success] 内容 ’
‘ >[!danger] 内容 ’
‘ >[!info] 内容 ’
‘ >[!primary] 内容 ’

内容

直接粘贴就能用了,简单吧