当前位置: 首页 > 中文手册 > jQuery Validator extend 继承指定校验规则

jQuery Validator extend 继承指定校验规则

jQuery Validator中的特殊规则属性extend用于指定当前校验规则继承指定校验规则的定义。

语法

jQuery Validator 1.0 新增

// 在校验规则对象中指定该属性
extend: "ruleName"

参数

参数描述
ruleNameString类型指定的校验规则名称。

如果在校验规则中指定了规则继承属性extend,则表示当前规则会继承指定校验规则的全部定义。当然,如果当前校验规则与被继承的"父类"校验规则具有同样的属性,则以当前校验规则自身的属性为准。

如果存在如下校验规则定义:

v.define("rule1", { "a": "a1", "b": "b1", "c": "c1", "d": "d1" });
// rule1 = { "a": "a1", "b": "b1", "c": "c1", "d": "d1"}

v.define("rule2", { "extend": "rule1", "c": "c2" });
// rule2 = { "a": "a1", "b": "b1", "c": "c2", "d": "d1"}

v.define("rule3", { "extend": "rule2", "b": "b3" }),
// rule3 = { "a": "a1", "b": "b3", "c": "c2", "d": "d1"}

示例&说明

使用规则继承属性extend,可以非常方便地在指定规则的基础上进行"微调"。如果被继承的规则比较复杂,你也无需重复编写较多的规则定义代码。同时,它也可以使多个"子"校验规则随着"父类"校验规则定义的改变,而自动继承相应的改变,有利于校验规则的统一维护。

以如下HTML表单为例:

<form action="http://www.365mini.com/">
	<div>
		<label>售价</label>:
		<input id="price" name="price" palceholder="" type="text" >
	</div>
	<div>
		<label>成本价</label>:
		<input id="costPrice" name="costPrice" type="text" >
	</div>
	<input type="submit" value="提交" />
</form>

我们可以使用extend规则继承完成如下校验:运行代码

v.define("price", {
	required: true,
	pre: "trimAll,flush",
	format: "number/money",
	range: "(0,10000]"
});

// 在表单提交时执行校验
$("form").v("submit", {
	"#price": "price",
	"#costPrice": {
		extend: "price", // 继承规则"price"
		required: false // 但允许为空
	}
});
5 0
我们认为: 用户的主要目的,是为了获取有用的信息,而不是来点击广告的。因此本站将竭力做好内容,并将广告和内容进行分离,确保所有广告不会影响到用户的正常阅读体验。用户仅凭个人意愿和兴趣爱好点击广告。
我们坚信:只有给用户带来价值,用户才会给我们以回报。
CodePlayer技术交流群1CodePlayer技术交流群1

帮朋友打一个硬广告:

P2P网贷系统(Java版本) 新年低价大促销,多年P2P技术积累,系统功能完善(可按需定制,可支持第三方存管、银行存管),架构稳定灵活、性能优异、二次开发快速简单。 另可提供二次开发、安装部署、售后维护、安全培训等一条龙服务。

外行看热闹,内行看门道。可以自信地认为,在系统设计上,比市面上的晓风、迪蒙、方维、绿麻雀、国融信、金和盛等P2P系统要好。
深圳地区支持自带技术人员现场考察源代码、了解主要技术架构,货比三家,再决定是否购买。

也可推荐他人购买,一旦完全成交,推荐人可获得实际售价 10% 的返现。
有意向者,详情请 点击这里 联系,工作时间立即回复。