代码:
<link href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet" /> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script> <script> $(function($) { //After it toggle the content with this button $('.content_toggle').hide(); $('.link-toggle').before('<i class="fa fa-caret-right"></i>'); $(".link-toggle").click(function() { $(this).toggleClass('active'); $(this).next(".project .content_toggle").slideToggle("slow"); $(this).closest('.project').find('i').toggleClass('fa-caret-right fa-caret-down'); }); }); </script> <div class="project"> <h4 class="link-toggle">Link 1</h4> <div id="" class="content_toggle"> <p>Hello world</p> </div> </div> <div class="project"> <h4 class="link-toggle">Link 2</h4> <div id="" class="content_toggle"> <p>Hello world</p> </div> </div>
DEMO: http://stackoverflow.com/questions/30932910/change-icons-when-toggle
参考:http://stackoverflow.com/a/30932938
jQuery 遍历 - closest() 方法
本例演示如何通过 closest() 完成事件委托。当被最接近的列表元素或其子后代元素被点击时,会切换黄色背景:
$( document ).bind("click", function( e ) { $( e.target ).closest("li").toggleClass("hilight"); });
定义和用法
closest() 方法获得匹配选择器的第一个祖先元素,从当前元素开始沿 DOM 树向上。
详细说明
如果给定表示 DOM 元素集合的 jQuery 对象,.closest() 方法允许我们检索 DOM 树中的这些元素以及它们的祖先元素,并用匹配元素构造新的 jQuery 对象。.parents() 和 .closest() 方法类似,它们都沿 DOM 树向上遍历。两者之间的差异尽管微妙,却很重要:
从当前元素开始 | 从父元素开始 |
沿 DOM 树向上遍历,直到找到已应用选择器的一个匹配为止。 | 沿 DOM 树向上遍历,直到文档的根元素为止,将每个祖先元素添加到一个临时的集合;如果应用了选择器,则会基于该选择器对这个集合进行筛选。 |
返回包含零个或一个元素的 jQuery 对象 | 返回包含零个、一个或多个元素的 jQuery 对象 |
请看下面的 HTML 片段:
<ul id="one" class="level-1"> <li class="item-i">I</li> <li id="ii" class="item-ii">II <ul class="level-2"> <li class="item-a">A</li> <li class="item-b">B <ul class="level-3"> <li class="item-1">1</li> <li class="item-2">2</li> <li class="item-3">3</li> </ul> </li> <li class="item-c">C</li> </ul> </li> <li class="item-iii">III</li> </ul>
例子 1
假设我们执行一个从项目 A 开始的对 <ul> 元素的搜索:
$('li.item-a').closest('ul').css('background-color', 'red');
这会改变 level-2 <ul> 的颜色,这是因为当向上遍历 DOM 树时会第一个遇到该元素。
例子 2
假设我们搜索的是 <li> 元素:
$('li.item-a').closest('li').css('background-color', 'red');
这会改变列表项目 A 的颜色。在向上遍历 DOM 树之前,.closest() 方法会从 li 元素本身开始搜索,直到选择器匹配项目 A 为止。
例子 3
我们可以传递 DOM 元素作为 context,在其中搜索最接近的元素。
var listItemII = document.getElementById('ii'); $('li.item-a').closest('ul', listItemII).css('background-color', 'red'); $('li.item-a').closest('#one', listItemII).css('background-color', 'green');
以上代码会改变 level-2 <ul> 的颜色,因为它既是列表项 A 的第一个 <ul> 祖先,同时也是列表项 II 的后代。它不会改变 level-1 <ul> 的颜色,因为它不是 list item II 的后代。
参考:http://www.w3school.com.cn/jquery/traversing_closest.asp
本文转自:Bootstrap 3: 图标转换事件 Change icons when toggle
相关推荐
Bootstrap5 图标库 bootstrap-icons
Bootstrap Icons:Bootstrap 有史以来第一次拥有自己的图标库,并且是专门为 Bootstrap 的组件和文档定制开发的。 Bootstrap Icons 的设计初衷是与 Bootstrap 组件配合使用,从表单到导航组件等。Bootstrap Icons ...
React Bootstrap图标 全新的用作React组件。 当前v1.3.0,有1265个图标! 安装 npm install react-bootstrap-icons --save 要么 yarn add react-bootstrap-icons 用法 import React from ' react ' ; import { ...
Bootstrap开源的SVG图标库,此图标库起初专门针对其从表单控件到导航等组件和文档进行定制设计和构建,现在可以免费用于任何项目,无论此项目是否使用了Bootstrap。 Bootstrap Icons是SVG图标库,因此它们可以快速...
Bootstrap图标Vue Bootstrap图标旨在与Bootstrap组件一起使用,从表单控件到导航。 但是,它们也可以在几乎任何项目中工作。 这是因为Bootstrap图标是SVG,因此它们可以快速轻松地缩放并可以使用CSS设置样式。 -该...
这是一款基于bootstrap的带图标的按钮样式。这组按钮在bootstrap按钮的基础上,通过附加的HTML元素来构建小图标,并通过CSS3来制作鼠标hover动画效果。
该资源为Bootstrap模态框练习的源码,里面包含了项目所需要的bootstrap.min.css、bootstrap.js、jquery-1.12.4.js文件
主要为大家详细介绍了本地Bootstrap文件字体图标引入却无法显示问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
下载过来的,改了一下,基本满足需求,访问地址: bootstrap-fileinput-master\examples\demo.html
django-bootstrap3:集成了 Bootstrap 3 的 Django。 Django 的 Bootstrap 3 Django 的 Bootstrap 3 集成。 目标 本项目的目标是将 Django 和 Bootstrap 3 无缝融合。想在 Django 中使用 Bootstrap 4? 请参阅 ...
1. IconPark IconPark 提供超过 2400 个高质量图标,还提供了每个图标的含义和来源的描述,便于开发者使用。除此之外,该网站还可以自定义图标,这是与其他图标网站与众不同的地方。...Bootstrap Icons
超好超棒的bootstrap-toggle-buttons用在网页很不错
django-bootstrap3:集成了 Bootstrap 3 的 Django。
Rails :: Bootstrap :: Toggle :: Buttons 这款宝石旨在提供捆绑在简单宝石中的靴子。 安装 将此行添加到您的应用程序的Gemfile中: gem 'rails-bootstrap-toggle-buttons' 然后执行: $ bundle 或将其自己安装...
资源分类:Python库 所属语言:Python 资源全名:django_bootstrap_icons-0.6.1-py3-none-any.whl 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
内有bootstrap文件在resource里,版本3.3.7 demo文件里是html文件,里面有bootstrap的图标大全
Vue引导程序图标 一个Vue.js组件,用于通过SVG sprite方法呈现。 对于该组件的Vue 3版本,请查看 。 安装 npm install --save @dvuckovic/vue-bootstrap-icons 用法 全局组件注册: import Vue from 'vue' ; ...
Bootstrap图标字体 Bootstrap的官方开源SVG图标库。 访问并检查搜索功能,该功能具有用于标识常用图标名称和样式的关键字。 例如,如果您搜索“ swift”,我们将调出可能用作箭头的每个图标。 我们还包括了每个...
下载bootstrap的js,css文件: 在jsp中的应用: 第一步: 新建一个web项目 将bootstrap下载下来的文件放入WEB-INF下面的,lib目录下,新建一个bootstrap文件: 第二步: 新建一个index.jsp文件,引入所使用的...