在查看了HowTo和Meteor
EJSON文档之后,我们可以使用
EJSON.addType方法序列化RegEx
。
扩展RegExp- 为RegExp提供
EJSON.addType实现所需的方法。
RegExp::options = -> opts = [] opts.push 'g' if @global opts.push 'i' if @ignoreCase opts.push 'm' if @multiline return opts.join('')RegExp::clone = -> self = @ return new RegExp(self.source, self.options())RegExp::equals = (other) -> self = @ if other isnt instanceOf RegExp return false return EJSON.stringify(self) is EJSON.stringify(other)RegExp::typeName = -> return "RegExp"RegExp::toJSonValue = -> self = @ return { 'regex': self.source 'options': self.options() }
呼叫EJSON.addType- 在任何地方进行。最好使它可用于客户端和服务器。这将反序列化
toJSONValue上面定义的对象。
EJSON.addType "RegExp", (value) -> return new RegExp(value['regex'], value['options'])
在控制台中测试 -不要相信我。你自己看。
> o = EJSON.stringify(/^Mooo/ig)"{"$type":"RegExp","$value":{"regex":"^Mooo","options":"ig"}}"> EJSON.parse(o)/^Mooo/gi
这样一来,您就可以在客户端和服务器上对RegExp进行序列化和解析,可以通过有线传递,保存在Session中,甚至可以存储在查询集合中!
编辑以添加IE10 +错误:错误:在严格模式下 , 不允许分配只读属性 由@Tim Fletcher提供
import { EJSON } from 'meteor/ejson';function getOptions(self) { const opts = []; if (self.global) opts.push('g'); if (self.ignoreCase) opts.push('i'); if (self.multiline) opts.push('m'); return opts.join('');}RegExp.prototype.clone = function clone() { return new RegExp(this.source, getOptions(this));};RegExp.prototype.equals = function equals(other) { if (!(other instanceof RegExp)) return false; return EJSON.stringify(this) === EJSON.stringify(other);};RegExp.prototype.typeName = function typeName() { return 'RegExp';};RegExp.prototype.toJSonValue = function toJSonValue() { return { regex: this.source, options: getOptions(this) };};EJSON.addType('RegExp', value => new RegExp(value.regex, value.options));
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)