2010-06-29 63 views
0

我还有另一个wtf与jQuery的时刻。应该包含哪些文件才能使用jQuery选项卡?

我进口下列文件(其中包括)

<script src="../../Scripts/jquery-1.4.1.min.js" type="text/javascript"></script> 
<script src="../../Scripts/jquery.ui.core.min.js" type="text/javascript"></script> 
<script src="../../Scripts/jquery.ui.tabs.min.js" type="text/javascript"></script> 

HTML:

<div id="tabs"> 
    <ul> 
    <li><a href="#tabs-1">test1</a></li> 
    <li><a href="#tabs-2">test2</a></li> 
    <li><a href="#tabs-3">test3</a></li> 
    </ul> 
    <div id="tabs-1"> 
    <p>test1 content</p> 
    </div> 
    <div id="tabs-2"> 
    <p>test2 content</p> 
    </div> 
    <div id="tabs-3"> 
    <p>test3 content</p> 
    </div> 
</div> 

的javascript:

$(document).ready(function() { 
    alert($("#tabs"));  // '[object Object]' 
    alert($("#tabs").tabs) // 'undefined' 
    $("#tabs").tabs();  // doesn't work 
    alert('working');  // doesn't reach this line 
}); 

我实在不明白这是如何都不可能困难,但我仍然设法花费2个小时而没有得到它的工作。有任何想法吗?

回答

1

当我为标签页自定义下载时,它只会显示“Widget是Tabs需要的依赖项”,所以它看起来像你需要的(如果你还没有)窗口部件代码。

这已经过压缩:

/*! 
* jQuery UI Widget 1.8.2 
* 
* Copyright (c) 2010 AUTHORS.txt (http://jqueryui.com/about) 
* Dual licensed under the MIT (MIT-LICENSE.txt) 
* and GPL (GPL-LICENSE.txt) licenses. 
* 
* http://docs.jquery.com/UI/Widget 
*/ 
(function(b){var j=b.fn.remove;b.fn.remove=function(a,c){return this.each(function(){if(!c)if(!a||b.filter(a,[this]).length)b("*",this).add(this).each(function(){b(this).triggerHandler("remove")});return j.call(b(this),a,c)})};b.widget=function(a,c,d){var e=a.split(".")[0],f;a=a.split(".")[1];f=e+"-"+a;if(!d){d=c;c=b.Widget}b.expr[":"][f]=function(h){return!!b.data(h,a)};b[e]=b[e]||{};b[e][a]=function(h,g){arguments.length&&this._createWidget(h,g)};c=new c;c.options=b.extend({},c.options);b[e][a].prototype= 
b.extend(true,c,{namespace:e,widgetName:a,widgetEventPrefix:b[e][a].prototype.widgetEventPrefix||a,widgetBaseClass:f},d);b.widget.bridge(a,b[e][a])};b.widget.bridge=function(a,c){b.fn[a]=function(d){var e=typeof d==="string",f=Array.prototype.slice.call(arguments,1),h=this;d=!e&&f.length?b.extend.apply(null,[true,d].concat(f)):d;if(e&&d.substring(0,1)==="_")return h;e?this.each(function(){var g=b.data(this,a),i=g&&b.isFunction(g[d])?g[d].apply(g,f):g;if(i!==g&&i!==undefined){h=i;return false}}):this.each(function(){var g= 
b.data(this,a);if(g){d&&g.option(d);g._init()}else b.data(this,a,new c(d,this))});return h}};b.Widget=function(a,c){arguments.length&&this._createWidget(a,c)};b.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",options:{disabled:false},_createWidget:function(a,c){this.element=b(c).data(this.widgetName,this);this.options=b.extend(true,{},this.options,b.metadata&&b.metadata.get(c)[this.widgetName],a);var d=this;this.element.bind("remove."+this.widgetName,function(){d.destroy()});this._create(); 
this._init()},_create:function(){},_init:function(){},destroy:function(){this.element.unbind("."+this.widgetName).removeData(this.widgetName);this.widget().unbind("."+this.widgetName).removeAttr("aria-disabled").removeClass(this.widgetBaseClass+"-disabled ui-state-disabled")},widget:function(){return this.element},option:function(a,c){var d=a,e=this;if(arguments.length===0)return b.extend({},e.options);if(typeof a==="string"){if(c===undefined)return this.options[a];d={};d[a]=c}b.each(d,function(f, 
h){e._setOption(f,h)});return e},_setOption:function(a,c){this.options[a]=c;if(a==="disabled")this.widget()[c?"addClass":"removeClass"](this.widgetBaseClass+"-disabled ui-state-disabled").attr("aria-disabled",c);return this},enable:function(){return this._setOption("disabled",false)},disable:function(){return this._setOption("disabled",true)},_trigger:function(a,c,d){var e=this.options[a];c=b.Event(c);c.type=(a===this.widgetEventPrefix?a:this.widgetEventPrefix+a).toLowerCase();d=d||{};if(c.originalEvent){a= 
b.event.props.length;for(var f;a;){f=b.event.props[--a];c[f]=c.originalEvent[f]}}this.element.trigger(c,d);return!(b.isFunction(e)&&e.call(this.element[0],c,d)===false||c.isDefaultPrevented())}}})(jQuery); 
; 
+0

这是固定不变的呢!谢谢!!!!!!如果将它包含在文档中的依赖关系列表中,我们不会浪费半天的时间:生气的脸: – fearofawhackplanet 2010-06-29 13:56:14

+0

确实如此,但它并未列出widget作为其中之一: S,它只是当我去建立自定义下载它说它是必需的。哦,你很受欢迎。 – 2010-06-29 13:58:01

2

如果您只需要它的一个子集,就可以更容易地将jQuery UI作为一个包使用,you can configure your download here

这样你包括一个.js的jQuery UI页面上,而不是试图找出依赖:)

或者,您可以包括从CDN,such as google's满库,就像这样:

<script type="text/javscript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.2/jquery-ui.min.js"></script> 

如果您使用的是默认主题,它们也会托管CSS(请务必更改URL中的版本)。 You can see a question with links to that here

相关问题