这篇文章主要介绍了Angular中点击li标签实现更改颜色的核心代码,需要的朋友可以参考下
点击ng-repeat遍历后的li标签,实现更改border颜色;
html代码:
<ul ng-if="params.questionTypeId == 8"> <li class="gamePre-def" ng-repeat=" word in wordsDef" ng-click='li_click($index)' ng-class='{focus: $index == focus}'> {{word}}</li> </ul>
js代码:
$scope.li_click = function (i) { $scope.focus = i; };
说明:
①在8b5f8b1972378d9df41b5958cd285f77元素的单击事件中,将执行$scope对象中添加的"li_click()"方法;
②在该方法中将"$index(行号值)"作为实参传给方法,并将"focus"属性值设为“$index”值;
③因此当单击某行8b5f8b1972378d9df41b5958cd285f77元素时,"focus"属性值将变为相应的"$index";
④此时,8b5f8b1972378d9df41b5958cd285f77元素的"ng-class"样式指令通过key/value对象的方式指定该元素需要添加的样式,由于单击8b5f8b1972378d9df41b5958cd285f77元素时,"$index"变量值和"focus"属性值相同,也就是说"$index==focus"的返回值为true;
⑤此时您应该明白了,"ng-class"的样式指令值变为"focus";
⑥经过上面的分析及操作,我们实现了单击8b5f8b1972378d9df41b5958cd285f77元素时,添加border的效果.
css样式:
ul .focus { border: 1px solid blue; }
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
在React Native中使用prop-types如何实现属性确认
以上是在Angular中如何实现颜色变化的详细内容。更多信息请关注PHP中文网其他相关文章!