diff --git a/src/components/utils/ObjectUtils.js b/src/components/utils/ObjectUtils.js index 425d4cec1..9a6ee1118 100755 --- a/src/components/utils/ObjectUtils.js +++ b/src/components/utils/ObjectUtils.js @@ -58,27 +58,32 @@ export default class ObjectUtils { } static resolveFieldData(data, field) { - if (typeof field === 'function') { - return field(data); - } - else { - if (data && field) { - if (field.indexOf('.') === -1) { - return data[field]; - } - else { - let fields = field.split('.'); - let value = data; - for (var i = 0, len = fields.length; i < len; ++i) { - value = value[fields[i]]; - } - return value; - } + if (data && field) { + if (this.isFunction(field)) { + return field(data); + } + else if(field.indexOf('.') === -1) { + return data[field]; } else { - return null; + let fields = field.split('.'); + let value = data; + for(var i = 0, len = fields.length; i < len; ++i) { + if (value == null) { + return null; + } + value = value[fields[i]]; + } + return value; } } + else { + return null; + } + } + + static isFunction(obj) { + return !!(obj && obj.constructor && obj.call && obj.apply); } static filter(value, fields, filterValue) {