/** * Created by zrz on 2015/9/16,15:01. * @version 1.1.0 */

var aa = {
    name: "张三",
    id: 110,
    address: "北京市和平门1路2街3胡同4门5户",
    phoneNumber: 12345678910,
    price: 220,
    off1: 44,
    off2: 55
};
var bb = {
    name: "李四",
    id: 120,
    address: "北京市和平门5路4街3胡同2门1户",
    phoneNumber: 12345678911,
    price: 1421,
    off1: 454,
    off2: 515
};

var setOrder = function (_order) {
    this.off = parseInt(_order.id);
    this.name = _order.name;
    this.address = _order.address;
    this.price = _order.price;
    this.off1 = _order.off1;
    this.off2 = _order.off2;
    setOrder.getMethod('address');
    setOrder.getMethod('name');
    setOrder.getMethod('price');
    var that=this;
    setOrder.method('getOff', function () {
        return that.off1 + that.off2;
    });
    setOrder.method('getMoney',function(){
        return that.price-that.getOff();
    });
};

/** * 实体类原型绑定函数 * @param name 函数名称 * @param func 函数具体内容 * @returns {Function} */
Function.prototype.method = function (name, func) {
    if (!this.prototype[name]) {
        this.prototype[name] = func;
    }
    return this;
};

/** * 实体类原型绑定get函数 * @param _name 需要读取的值 * @param func 若无,则默认是getName函数,_name的首字母会自动大写;若有定义,则执行定义的函数 * @returns {Function} */
Function.prototype.getMethod = function (_name, func) {
    var _getName = "get" + _name.substr(0, 1).toUpperCase() + _name.substr(1, _name.length - 1);//首字母大写
    if (!this.prototype[_getName]) {
        this.prototype[_getName] = func || function () {
            return this[_name];
        };
    }
    return this;
};

console.info(new setOrder(aa).getPrice(), new setOrder(aa).getOff(), new setOrder(aa).getMoney());
console.info(new setOrder(bb).getPrice(), new setOrder(bb).getOff(), new setOrder(bb).getMoney());

更多相关文章

  1. 使用超类中的构造函数
  2. JavaScript中的map()函数
  3. 自定义MapReduce输入格式 - 找不到构造函数
  4. 关于webview中java调用js函数(解决loadUrl函数没反应)
  5. 使用Java中的Scala:将函数作为参数传递
  6. 关于Javascript中声明变量、函数的笔记
  7. 异步执行多个任务并在JavaScript函数中返回第一个成功的结果

随机推荐

  1. 如何使用Watir访问自定义属性的元素?
  2. 采用HTML5的开源组件绘制复杂图形
  3. winform内嵌html,通过Flot插件实现图表显
  4. HTML+CSS:css定位详解之相对定位、绝对定
  5. a标签下图片居中
  6. 用于将Word文档文本转换为HTML的库
  7. css造型图中的点
  8. tomahawk JSF组件扩展组件(一)
  9. 这是一个关于HTML编辑器的功能测试
  10. IE6使用innerHTML加入img标签图片不显示