谢谢peernohell,它把我推得更远了。无论如何,当从 getContent 方法返回时, var content 仍然是未定义的,我知道这些是范围问题,所以我问我提出了一个错误的问题。如何在这种情况下准确地处理范围,如下所示:
!function ($) {
"use strict"; // jshint ;_;
/* POPOVER PUBLIC CLASS DEFINITION
* =============================== */
var Popover = function (element, options) {
this.init('popover', element, options)
}
/* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
========================================== */
Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype, {
constructor: Popover
, setContent: function () {
var $tip = this.tip()
, title = this.getTitle()
, content = this.getContent()
$tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
$tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
$tip.removeClass('fade top bottom left right in')
}
, hasContent: function () {
return this.getTitle() || this.getContent()
}
, getUrl: function (){
var el = this.$element;
var url = 'http://www.google.com/finance/info?infotype=infoquoteall&q=' +
this.getId() +
'&callback=?'
;
return url;
}
, getId : function(){
var tooltipId
, id = this.$element
, o = this.options
tooltipId = id.attr('data-load');
return tooltipId;
}
, getData: function (callback) {
var url = this.getUrl();
var result = [];
$.ajax({
url: url,
dataType: "json",
success: function (data) {
$.each(data, function (entryIndex, entry) {
result.push(entry.t);
});
callback(result);
},
error: function () {
calllback();
}
});
}
, getContent: function() {
var content
, $e = this.$element
, o = this.options
content = this.getData(function(result){
var info = result.toString();
return info;
});
return content
}
, tip: function () {
if (!this.$tip) {
this.$tip = $(this.options.template)
}
return this.$tip
}
, destroy: function () {
this.hide().$element.off('.' + this.type).removeData(this.type)
}
})
/* POPOVER PLUGIN DEFINITION
* ======================= */
var old = $.fn.popover
$.fn.popover = function (option) {
return this.each(function () {
var $this = $(this)
, data = $this.data('popover')
, options = typeof option == 'object' && option
if (!data) $this.data('popover', (data = new Popover(this, options)))
if (typeof option == 'string') data[option]()
})
}
$.fn.popover.Constructor = Popover
$.fn.popover.defaults = $.extend({} , $.fn.tooltip.defaults, {
placement: 'top'
, trigger: 'hover'
, content: ''
, template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
})
/* POPOVER NO CONFLICT
* =================== */
$.fn.popover.noConflict = function () {
$.fn.popover = old
return this
}
}(window.jQuery);