本文介绍了AngularJS点击添加样式、点击变色设置的实例代码,分享给大家,具体如下:
首先解释需求是这样的,有个列表,当你点击哪一行时,哪一行背景变成灰色,在JQ中,大家都知道,这是非常容易的,加一个addClass就行了,那么AngularJS如何实现呢?
下面我们看代码部分
添加元素样式 body{font-size:12px} ul{margin:0;padding:0;width:408px;list-style-type:none} ul li{float:left;padding:5px 0} ul .odd{color:#0026ff} ul .even{color:red} ul .bold{font-weight:700} ul li span{float:left;padding:0 10px;width:52px} ul .focus{background-color:#ccc}
- 序号 姓名 性别 是否首条 是否尾条
- {{$index+1}} {{stu.name}} {{stu.sex}} {{$first?'是':'否'}} {{$last?'是':'否'}}
1、首先,第一个< li >元素的"ng-class"值与"bold"属性值绑定,使得该值指定的样式加粗,这个相信大家都能看懂;
2、使用“ng-class-odd”和"ng-class-even"样式分别绑定奇数和偶数行的样式,从而实现了隔行换色的功能;
3、最后我们解释一下,如何使得所点击的< li >元素变色
①在< li >元素的单击事件中,将执行$scope对象中添加的"li_click()"方法;
②在该方法中将"$index(行号值)"作为实参传给方法,并将"focus"属性值设为“$index”值;
③因此当单击某行< li >元素时,"focus"属性值将变为相应的"$index";
④此时,< li >元素的"ng-class"样式指令通过key/value对象的方式指定该元素需要添加的样式,由于单击< li >元素时,"$index"变量值和"focus"属性值相同,也就是说"$index==focus"的返回值为true;
⑤此时您应该明白了,"ng-class"的样式指令值变为"focus";
⑥经过上面的分析及操作,我们实现了单击< li >元素时,添加背景样式的效果.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。



