angular.js - angular ng-repeat改变某个的背景颜色
问题描述
如图所示,上面的5个块,用ng-repeat循环输出,怎样实现当点击某一块(如块2)时,该块的背景颜色变为红色?其他的块的颜色不变。谢谢指点。
问题解答
回答1:方法太多,ng-click,ng-class,directive实现都可以啊这是直接写的方法,仅供参考html:
<p> <span ng- ng-repeat='s in list' ng-bind='s' ng-click='changeStatus(s)'></span></p>
js
$scope.list = [1,2,3,4,5];$scope.changeStatus = function(index){ $scope.selected = index;}回答2:
添加点击事件。把当前循环的$index和$event传过去。然后自己通过angular jq来就处理就OK啊。
回答3:给你个现成的代码:HTML
<p class=’options’> <span class=’option’ ng- ng-repeat='s in orderStatus' ng-bind='s.l' ng-click='clickStatus(s)'></span></p>
JS
$scope.clickStatus = function(prop) { prop._selected = !prop._selected;};
CSS
.option{display:inline-block;border:1px solid green;padding:.25em;margin:.5em .5em 0 0;}.option.selected{background:green;color:white;}
我正打算写个directive做这个
回答4:http://runjs.cn/detail/yfnwk6ho
相关文章:
1. javascript - node服务端渲染的困惑2. html5 - h5写的app用的webview,用手机浏览器打开不显示?3. javascript - 百度echarts series数据更新问题4. javascript - webpack --hot 热重载无效的问题5. php - 第三方支付平台在很短时间内多次异步通知,订单多次确认收款6. mysql - 一个表和多个表是多对多的关系,该怎么设计7. python - django 按日归档统计订单求解8. 我在导入模板资源时遇到无法显示的问题,请老师解答下9. Mysql && Redis 并发问题10. 请教一个python字符串处理的问题?
