业务系统的核心其实就是 "状态" 和 "规则":
- 状态(State) :用户数据、订单、账户余额、审批状态等。这对应
typedef
。 - 规则(Rule) :"如果订单金额超过100元,则免运费"、"如果用户是VIP,则打9折"、"当状态变为'已付款'时,通知仓库发货"。这对应
ruledef
。
Imsure 的范式直接将代码和业务逻辑对齐了。我们来看一个对比:
传统命令式(Imperative)方式(复杂)
typescript
// 1. 分散的状态修改点:你需要找到所有修改 order.amount 的地方
function updateOrderAmount(order, newAmount) {
order.amount = newAmount
// 2. 必须手动调用规则函数,容易遗漏
applyShippingRule(order)
applyDiscountRule(order)
}
function applyShippingRule(order) {
order.shippingCost = order.amount > 100 ? 0 : 10
}
// 3. 依赖多个条件时需要在所有更新的地方都调用函数,容易遗漏
function applyDiscountRule(order) {
if (order.user.isVip) {
order.discount = order.amount * 0.1
}
// ... 可能还有其他规则
}
痛点 :状态修改和规则执行是解耦的。开发者必须"命令"程序在正确的时间、正确的地点调用正确的规则,极易出错和遗漏。
Imsure 声明式(Declarative)方式(简单)
typescript
const Order = typedef({
amount: float64,
shippingCost: float64,
discount: float64,
user: User,
});
// 规则1:直接声明"当金额变化时,运费规则是什么"
ruledef(Order, 'shippingRule', {
amount: true,
}, (order) => {
order.shippingCost = order.amount > 100 ? 0 : 10
});
// 规则2:声明"当金额或用户VIP状态变化时,折扣规则是什么"
ruledef(Order, 'discountRule', {
'@or': true,
amount: true,
user: {
isVip: true,
},
}, (order) => {
if (order.user.isVip) {
order.discount = order.amount * 0.1
} else {
order.discount = 0
}
});
优势:
- 自治性 :规则与状态绑定。无论
amount
在何处、以何种方式被修改,规则都会自动触发。不可能遗漏。 - 高内聚 :所有关于"运费"的逻辑都集中在
shippingRule
这一个地方,而不是散落在代码库的各个角落。 - 可声明性:代码读起来就像业务文档:"当金额变化,那么运费等于..."。
- 易于扩展 :添加一个新规则(例如,"黑五期间所有运费打五折")就是添加一个新的
ruledef
,而无需修改任何现有规则函数。
核心优势:应对变化
业务逻辑是永远在变化 的。今天的规则可能明天就失效。这种范式的最大优势在于改变代码的成本极低。
需求变更:"除了金额超过100,如果商品重量超过10kg,也要收取额外运费。"
-
命令式 :你需要找到
applyShippingRule
函数,修改它的逻辑,可能要引入新的状态(productWeight
),并确保这个状态在更新时也会调用此函数。风险很高。typescriptfunction applyShippingRule(order) { let cost = 10 if (order.amount > 100) cost -= 10 // 免运费10元 if (order.productWeight > 10) cost += 5 order.shippingCost = Math.max(cost, 0) // 运费不能为负 } // 还要记得在更新 productWeight 的地方也调用这个函数!
-
声明式 :只需修改原来的规则定义。依赖系统会自动处理好一切,因为规则现在也依赖
productWeight
字段。typescriptruledef(Order, 'shippingRule', { '@or': true, amount: true, productWeight: true, // 添加新依赖 }, (order) => { let cost = 10 if (order.amount > 100) cost -= 10 // 免运费10元 if (order.productWeight > 10) cost += 5 order.shippingCost = Math.max(cost, 0) // 运费不能为负 });
业务逻辑的"终极简单"
虽然它不太适合处理计算业务,但对于业务逻辑这个领域,它无限接近了"终极简单"。
它成功地将程序员从繁琐的、容易出错的"控制流"管理 中解放出来,让其专注于声明"数据"和"规则"本身 。这极大地降低了心智负担,使代码更能抵抗需求变化带来的冲击,从而在长期的软件维护和演化过程中,体现出其巨大的简单性和优越性。