Create a Bootstrap Headline
现在,让我们从头开始练习我们的HTML, CSS 和 Bootstrap 技术。
我们将会搭建一个 jQuery playground,它也即将在我们接下来的 jQuery 课程中被投入使用。
首先,创建一个 h3 元素,并且包含文本内容 jQuery Playground 。
在 h3 元素中设置 Bootstrap 的 class 属性 text-primary 为其上色,同时增加 Bootstrap 的 class 属性 text-center 使文本居中显示。
jQuery playground
House our page within a Bootstrap Container Fluid Div
现在让我们确保页面里所有的内容都是响应式的。
让我们将 h3 元素放置于一个class属性为 container-fluid 的 div 元素中。
Create a Bootstrap Row
现在将要为我们的内联元素创建一个 Bootstrap 行。
在 h3 标签下创建一个 div 元素,并且带有 class 属性 row 。
Split your Bootstrap Row
既然我们已经有了一个 Bootstrap 行,让我们来把它分成两栏来放置我们的元素吧。
在你的行内添加两个 div 元素,每个都具有 col-xs-6 class 属性。
Create Bootstrap Wells
Bootstrap 有一个 class 属性叫做 well,它的作用是为设定的列创造出一种视觉上的深度感(一种视觉上的效果,动手写代码体会一下)。
Well 是一种会引起内容凹陷显示或插图效果的容器
。为了创建 Well,只需要简单地把内容放在带有 class .well 的中即可。【案例】
在你的每一个class为col-xs-6的div 元素中都嵌入一个带有 well class 属性的 div 元素。
jQuery Playground
【图样】
Add Elements within your Bootstrap Wells
现在我们已经在行内的每一列都嵌套了好几层 div 元素了。这已经足够了。现在让我们添加 button 元素吧。
在每一个 well div 元素下放置三个 button 元素。
Apply the Default Bootstrap Button Style
Bootstrap 还有一种属于按钮的 class 属性叫做 btn-default 。
为你的每一个 button 元素增加两个 class 属性: btn 和 btn-default 。
Create a Class to Target with jQuery Selectors
并不是每一个 class 属性都是用于 CSS 的。 有些时候我们创建一些 class 只是为了更方便地在jQuery中选中这些元素。
例如,为你的每一个 button 都添加 target class。
Add ID Attributes to Bootstrap Elements
回忆一下,我们除了可以给元素增加 class 属性,还可以给你的每个元素增添一个 id 属性。
每一个指定元素的 id 都是唯一的,并且在每个页面中只能使用一次。
现在给我们每个包含 class well 的 div 元素一个唯一的 id。
记住,你可以像这样赋予一个元素 id:
例如本案例给左边的 well 赋予 id left-well。给右边的 well 赋予 id right-well。
Label Bootstrap Wells
让我们为我们的 wells 都标上它们的 id 吧。
在 left-well 之上,class为 col-xs-6 的 div 元素里面,添加一个文本为 #left-well 的 h4元素。
在 right-well 之上,class为 col-xs-6 的 div 元素里面,添加一个文本为 #right-well 的 h4元素。
Give Each Element a Unique ID
我们也可以使用jQuery并通过每个按钮各自唯一的 id 来标识出它们。
给你的每一个按钮一个唯一的 id ,以 target1 为开始,target6 为结束。
确保 target1 到 target3 在 #left-well 之中,target4 到 target6 则在 #right-well 之中。
Label Bootstrap Buttons
正如我们标注了每个 wells, 我们同样想要标注每一个按钮。
为你的每个 button 元素选择与其 id 选择器相同的文本。
Use Comments to Clarify Code
当我们开始使用jQuery,我们将修改HTML元素,但是实际上我们并不是直接在 HTML 文本中修改。
我们必须确保让每个人都知道,他们不应该直接修改此页面上这些代码。
记住,你可以在 为结束的地方进行评论注释。(像这样, )
请在你的 HTML 顶部加如下一段注释:Only change code above this line. 。
jQuery
Learn how Script Tags and Document Ready Work
现在让我们开始学习最流行的JavaScript库jQuery吧,不用担心JavaScript本身,我们稍后会提到它。
在开始学习使用jQuery之前,我们需要加一些代码到HTML文件中。
首先在页面顶端增加一行script元素,然后写上结束符。
浏览器会运行script 里所有的Javascript,包括jQuery。
在你的script里,添加这个方法:$(document).ready(function() {到你的script,接下来用});结束这个方法
接下来我们来学习如何写方法,方法里面的代码会被浏览器加载。
在没有document ready function以前,你的代码会在HTML没有渲染完成就执行,这样会产生bug。
jQuery Playground
#left-well
#right-well
Target HTML Elements with Selectors Using jQuery
,通常称作为 美元符号,或者简称为bling。
jQuery通过选择器来选择一个元素的,然后操作元素做些改变。
举个例子,要让所有的按钮做弹回效果,只要把这段代码写在document ready function里面就可以了。
$("button").addClass("animated bounce");
我们已经在后台为你引入了jQuery库和Animate.css库,这样你就可以在编辑器里直接可以使用这两个库,进而通过jQuery给button元素添加bounce回弹动画效果。
Target Elements by Class Using jQuery
你看到我们是怎么给所有的按钮做弹回效果了吗?我们用 $("button")来选中按钮,然后用.addClass("animated bounce")给按钮加CSS class。
你只需要用jQuery的.addClass()方法,就可以给元素加class了。
首先,我们来使用$(".well")来获取所有class为well的div元素。
仔细想想为什么需要在well前面添加.
然后使用jQuery的.addClass()方法添加2个class:animated、shake。
例如,你可以将下面的代码写在document ready function里:
$(".text-primary").addClass("animated shake");
[案例练习]给所有class为text-primary 的元素添加shake class。
Target Elements by ID Using jQuery
你还可以根据id属性来获取元素
首先用$("#target3")来选择id为target3的button元素。
注意,就像CSS一样,在id的名字前加上 #。
然后使用jQuery的.addClass()方法来添加 animated和fadeOutclass.
例如:下面的代码就是给id为target6的button元素添加fade out效果的:
$("#target6").addClass("animated fadeOut")
Delete your jQuery Functions
这些动画效果一开始很cool,但是动画太多就有点喧宾夺主了。
在你的document ready function里删掉那三条语句,只留document ready function。
Target the same element with multiple jQuery Selectors
现在你已经了解了3种选择器:元素选择器:$("button")、class选择器:$(".btn")、id选择器:$("#target1")。
尽管用.addClass()这种方式就可以加不同的class,不过还是让我们尝试用不同的方式给元素添加class吧。
[案例]
用上面介绍的jQuery选择器和addClass()方法:给所有type为button的元素添加animated class。
给所有class为.btn的按钮添加shake class。
给所有id为#target1的按钮添加btn-primary class。
$(document).ready(function() { $("button").addClass("animated"); $(".btn").addClass("shake"); $("#target1").addClass("btn-primary"); });
[注意]:是animated不是animate
Remove classes from an element with jQuery
你可以通过jQuery的addClass()方法给元素添加class,也可以通过jQueryremoveClass()方法去掉元素上的class。
像下面这样:
$("#target2").removeClass("btn-default");
Change the CSS of an Element Using jQuery
我们可以通过jQuery来改变HTML元素的CSS样式。
jQuery有一个叫做.css()的方法能让你改变元素的CSS样式。
我们是这样来把颜色改变成蓝色的:
$("#target1").css("color", "blue");
这跟通常的CSS语法有点不同,这里CSS的属性和值是在引号内的,并且用逗号分开。
Disable an Element Using jQuery
你还可以用jQuery改变除了CSS以外的属性。比如,你可以让按钮变不可选。
当你把按钮设置成不可选以后,这会让按钮变灰并且不能点击。
jQuery有一个.prop()的方法让你来调整元素的属性.
我们是这样来让按钮不可选的:
$("button").prop("disabled", true);
Change Text Inside an Element Using jQuery
jQuery不仅可以改变元素开始标记和结束标记间的文本,甚至可以改变元素标记本身。
jQuery的.html()方法可以添加HTML标签和文字到元素,而元素之前的内容都会被方法的内容所替换掉。
我们是通过em[emphasize]标签来重写和强调标题文本的:
$("h3").html("jQuery Playground");
jQuery 还有一个类似的方法叫.text(),它只能改变文本但不能修改标记。换句话说,这个方法只会把传进来的任何东西(包括标记)当成文本来显示。
Remove an Element Using jQuery
现在让我们用jQuery来移除页面上的HTML元素吧.
jQuery 有一个.remove() 的方法可以移除HTML元素
【案例】
试着使用.remove()方法来移除页面上的target4元素吧.$("#target4").remove();
Use appendTo to Move Elements with jQuery
现在让我们尝试把元素从一个div里移到另外一个div里。
jQuery有一个appendTo()方法可以把选中的元素加到其他元素中。
比如,你想让target4从我们本来的right-well移到left-well,我们可以这样使用:
$("#target4").appendTo("#left-well");
Clone an Element Using jQuery
除了移动元素,你还可以拷贝元素。简单理解:移动元素就是剪切,拷贝元素就是复制。
jQuery的clone()方法可以拷贝元素。
比如,如果我想把target2从left-well拷贝到right-well,我们可以这样写:
$("#target2").clone().appendTo("#right-well");
你有没有发现两个jQuery方法合在一起使用了?这就叫方法链function chaining,使用起来很方便。
Target the Parent of an Element Using jQuery
每个HTML元素根据继承属性都有父parent元素。
jQuery Playground
#left-well
#right-well
举个例子,h3 元素的父元素是
,的父元素是 body。jQuery有一个方法叫parent(),它允许你访问指定元素的父元素。
【举个例子】:让left-well 元素的父元素parent()的背景色变成蓝色。
$("#left-well").parent().css("background-color", "blue")
Target the Children of an Element Using jQuery
每个人都继承了自己的父母的一些属性,譬如:DNA、相貌、血型、体型等等,HTML也不例外。
许多HTML元素都有children(子元素),每个子元素都从父元素那里继承了一些属性。
【举个例子】每个HTML元素都是 body 的子元素, 你的 "jQuery Playground" h3 元素是
的子元素。jQuery有一个方法叫children(),它允许你访问指定元素的子元素。
举个例子:让left-well 元素的子元素children()的文本颜色变成蓝色。
$("#left-well").children().css("color", "blue")
Target a Specific Child of an Element Using jQuery
你已经看到了当用jQuery选择器通过id属性来选取元素的时候是多么方便,但是你不能总是写这么整齐的id。
幸运的是,jQuery有一些另外的技巧可以达到同样的效果。
jQuery 用CSS选择器来选取元素,target:nth-child(n) CSS选择器允许你按照索引顺序(【注意】:从1开始)选择目标元素的所有子元素。示例:你可以给目标元素的第三个子元素添加bounce class。
$(".target:nth-child(3)").addClass("animated bounce");
Target Even Numbered Elements Using jQuery
示例:获取class为target且索引为**奇数((的所有元素,并给他们添加class。
$(".target:odd").addClass("animated shake");
记住,jQuery里的索引是从0开始的,也就是说::odd 选择第2、4、6个元素,因为target#2(索引为1),target#4(索引为3),target6(索引为5)。
【备注】:奇数为odd,偶数为even
Use jQuery to Modify the Entire Page
我们已经玩了这么久的jQuery游乐场,是时候结束这一节了。
我们让整个body都有淡出效果(fadeOut):
$("body").addClass("animated fadeOut");
让我们做一些更为激动人心的事情,给body添加class animated 和hinge 。
【源码】:
jQuery Playground
#left-well
#right-well