gpt4 book ai didi

javascript - 让 Twitter Bootstrap 的 "Tabs"Javascript 在 Rails 应用程序上工作

转载 作者:行者123 更新时间:2023-11-29 10:52:10 25 4
gpt4 key购买 nike

Rails 应用程序上的 javascript 问题。

Twitter 文档使事情变得非常简单,但是我仍然无法让选项卡动态工作(选项卡切换和下拉)。我直接复制了他们的源代码并下载了他们的 javascript,并将其包含在我的 Rails 应用程序的 application.js 文件中。不确定我错过了什么。

HTML 文件:

<script>
$(function () {
$('#.tabs').bind('change', function (e) {
e.target // activated tab
e.relatedTarget // previous tab
})
</script>
<h3>Demo</h3>
<ul class="tabs" data-tabs="tabs">
<li class="active"><a href="#home">Home</a></li>
<li><a href="#profile">Profile</a></li>
<li><a href="#messages">Messages</a></li>
<li><a href="#settings">Settings</a></li>
<li class="dropdown" data-dropdown="dropdown">
<a href="#" class="dropdown-toggle">Dropdown</a>
<ul class="dropdown-menu">
<li><a href="#fat">@fat</a></li>
<li><a href="#mdo">@mdo</a></li>
</ul>
</li>
</ul>
<div id="my-tab-content" class="tab-content">
<div class="active tab-pane" id="home">
<p>Lorem Ipsum.</p>

Application.js 文件:

// Place your application-specific JavaScript functions and classes here
// This file is automatically included by javascript_include_tag :defaults
$(document).ready(function(){

!function( $ ){

"use strict"

function activate ( element, container ) {
container
.find('> .active')
.removeClass('active')
.find('> .dropdown-menu > .active')
.removeClass('active')

element.addClass('active')

if ( element.parent('.dropdown-menu') ) {
element.closest('li.dropdown').addClass('active')
}
}

function tab( e ) {
var $this = $(this)
, $ul = $this.closest('ul:not(.dropdown-menu)')
, href = $this.attr('href')
, previous
, $href

if ( /^#\w+/.test(href) ) {
e.preventDefault()

if ( $this.parent('li').hasClass('active') ) {
return
}

previous = $ul.find('.active a').last()[0]
$href = $(href)

activate($this.parent('li'), $ul)
activate($href, $href.parent())

$this.trigger({
type: 'change'
, relatedTarget: previous
})
}
}


/* TABS/PILLS PLUGIN DEFINITION
* ============================ */

$.fn.tabs = $.fn.pills = function ( selector ) {
return this.each(function () {
$(this).delegate(selector || '.tabs li > a, .pills > li > a', 'click', tab)
})
}

$(document).ready(function () {
$('body').tabs('ul[data-tabs] li > a, ul[data-pills] > li > a')
})

}( window.jQuery || window.ender );

});

最佳答案

您不需要第一个脚本(它仅作为示例包含在文档中,以防您需要的不仅仅是框中的内容)

您需要的是指向 Bootstrap 样式表的链接:

<link rel="stylesheet" href="your_bootstrap_folder/bootstrap.min.css">

和两个脚本(假设您有 jquery,否则首先包括它):

<script type="text/javascript" src="your_bootstrap_folder/js/bootstrap-tabs.js"></script>
<script type="text/javascript" src="your_bootstrap_folder/js/bootstrap-dropdown.js"></script>

最后是函数调用

<script>
$(function () {
$('.tabs').tabs()
})
</script>

这应该可以解决问题。

编辑:为了确保您的顺序正确,这里有一个完整的例子:

<!DOCTYPE html>

<html>
<head>
<title>bootstrap tabs test</title>
<link rel="stylesheet" href="path_to_bootstrap/bootstrap.min.css">
</head>

<body>
<ul class="tabs">
<li class="active"><a href="#">Home</a></li>
<li><a href="#">Profile</a></li>
<li><a href="#">Messages</a></li>
<li><a href="#">Settings</a></li>
<li><a href="#">Contact</a></li>
<li data-dropdown="dropdown" class="dropdown">
<a class="dropdown-toggle" href="#">Dropdown</a>
<ul class="dropdown-menu">
<li><a href="#">Secondary link</a></li>
<li><a href="#">Something else here</a></li>
<li class="divider"></li>
<li><a href="#">Another link</a></li>
</ul>
</li>
</ul>
<script type="text/javascript" src="path_to_jquery/jquery-1.6.1.min.js"></script>
<script type="text/javascript" src="path_to_bootstrap/js/bootstrap-tabs.js"></script>
<script type="text/javascript" src="path_to_bootstrap/js/bootstrap-dropdown.js"></script>
<script>
$(function () {
$('.tabs').tabs()
})
</script>

</body>
</html>

关于javascript - 让 Twitter Bootstrap 的 "Tabs"Javascript 在 Rails 应用程序上工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8133301/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com