angular.js - Angularjs中点击事件传递参数 给class更换样式。
问题描述
想要实现的图如下:
现在我已经把基本形状和功能实现了,可是点击一个图标,在“适配设备”旁更换图标,这个功能没有发生预期的结果。请教各位,我的那个部分写错的?
1、这里是“适配设备”旁边点击不同下拉框中的图标会被替换的图标。(就是我想要实现的功能。)
<i ng-class='{’ ico-screen-pc’:pc, ’ ico-screen-projector’:projector, ’ ico-screen-tv’:tv}'></i>
2、这部分是下拉框中 可以点击不同图标
<ul ng-show='show_apparatus'> <li ng-click='displayModeData.choose_display(’pc’)'> <i class='ico-screen-pc'></i> </li> <li ng-click='displayModeData.choose_display(’projector’)'> <i class='ico-screen-projector'></i> </li> <li ng-click='displayModeData.choose_display(’tv’)'> <i class='ico-screen-tv'></i> </li></ul>
3、这部分是js 的函数代码
$scope.pc = true;$scope.displayModeData = { pc: true, choose_display : function( displayMode ){$scope.pc = ( displayMode === ’pc’ );$scope.projector = ( displayMode === ’projector’ );$scope.tv = ( displayMode === ’tv’ ); }};
请教大家 我的哪部分写错了呢?
问题解答
回答1:来,按我的改:
$scope.displayModeData = { pc: true, choose_display : function( displayMode ){$scope.displayMode = displayMode; }};
<i ng-class='{’ ico-screen-pc’:displayMode === ’pc’, ’ ico-screen-projector’: displayMode === ’projector’, ’ ico-screen-tv’: displayMode === ’tv’}'></i>回答2:
<i class='{{selectedClass}}'> </i><ul ng-show='show_apparatus'> <li ng-click='$parent.selectedClass = icon.className' ng-repeat='icon in icons'><i class='{{icon.className}}'></i>asdadasd </li></ul>
$scope.icons = [ {title: ’PC显示屏’, className: ’ico-screen-pc’}, {title: ’投影仪’, className: ’ico-screen-projector’}, {title: ’TV显示屏’, className: ’ico-screen-tv’}];$scope.selectedClass = $scope.icons[0].className;
相关文章:
1. java - mybatis怎么实现在数据库中有就修改,没有就添加2. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题3. MYSQL新建用户设置可以远程访问的问题4. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)5. node.js - nodejs和前端JavaScript 字符串处理结果不一样是什么原因?6. angular.js - angularjs的自定义过滤器如何给文字加颜色?7. linux - 为什么我在mysql的my.cnf下找不到bind-address?8. mysql - 我的myeclipse一直连显示数据库连接失败,不知道为什么9. 各位谁知道这个CSS时候哪里出错了???10. mysql - SQL操作时间的函数?
![$fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题](http://www.haobala.com/attached/image/news/202205/093622cb60.png)