如何有效地将属性从对象复制到另一个对象?

Aze*_*edo 2 javascript jquery json object

我正在寻找一种以更有效的方式编写此代码的方法.在对象加载方法中,它将具有与选项中的条目一样多的行(至少).

var myPlugin = {
  // here are the 'plugin' default ptions
  option1: 'deafult1'
  , option2: 'deafult2'
  , option3: false
  , option4: true
  , optionN: 'deafultN'

  // here the plugin will receive an object ('options')
  load: function(options){
    if (options.option1) myPlugin.option1 = options.option1;
    if (options.option2) myPlugin.option2 = options.option2;
    //...
  }
}


myPlugin.load({
  option3: true
  , option5: '123'
});
Run Code Online (Sandbox Code Playgroud)

这是将选项加载到JS/jquery插件的正确方法吗?有没有办法使用for ()/ each()以更有效/整洁的方式加载选项对象

我想的是:

  load: function(options){
    $.each(options, function(index, opt){
      // how to load options from here?
      // something like:
      // myPlugin.  ->current opt property name = opt

   });
  }
Run Code Online (Sandbox Code Playgroud)

cli*_*all 5

$.extendjQuery网站上看一下.

这是一种简单的方法,可以跨对象或完全复制对象.例如,来自jQuery网站:

var defaults = { validate: false, limit: 5, name: "foo" };
var options = { validate: true, name: "bar" };

// Merge defaults and options, without modifying defaults
var settings = $.extend( {}, defaults, options );`
Run Code Online (Sandbox Code Playgroud)