AngularJS 入门教程之事件处理器详解


Posted in Javascript onAugust 19, 2016

在这一步,你会在手机详细信息页面让手机图片可以点击。

请重置工作目录:

git checkout -f step-10

手机详细信息视图展示了一幅当前手机的大号图片,以及几个小一点的缩略图。如果用户点击缩略图就能把那张大的替换成自己那就更好了。现在我们来看看如何用AngularJS来实现它。

步骤9和步骤10之间最重要的不同在下面列出。你可以在GitHub里看到完整的差别。

控制器

app/js/controllers.js

...
function PhoneDetailCtrl($scope, $routeParams, $http) {
 $http.get('phones/' + $routeParams.phoneId + '.json').success(function(data) {
 $scope.phone = data;
 $scope.mainImageUrl = data.images[0];
 });

 $scope.setImage = function(imageUrl) {
 $scope.mainImageUrl = imageUrl;
 }
}

//PhoneDetailCtrl.$inject = ['$scope', '$routeParams', '$http'];

在PhoneDetailCtrl控制器中,我们创建了mainImageUrl模型属性,并且把它的默认值设为第一个手机图片的URL。

模板

app/partials/phone-detail.html

<img ng-src="{{mainImageUrl}}" class="phone">

...

<ul class="phone-thumbs">
 <li ng-repeat="img in phone.images">
 <img ng-src="{{img}}" ng-click="setImage(img)">
 </li>
</ul>
...

我们把大图片的ngSrc指令绑定到mainImageUrl属性上。

同时我们注册一个ngClick处理器到缩略图上。当一个用户点击缩略图的任意一个时,这个处理器会使用setImage事件处理函数来把mainImageUrl属性设置成选定缩略图的URL。

测试

为了验证这个新特性,我们添加了两个端到端测试。一个验证主图片被默认设置成第一个手机图片。第二个测试点击几个缩略图并且验证主图片随之合理的变化。

test/e2e/scenarios.js

...
 describe('Phone detail view', function() {

...

 it('should display the first phone image as the main phone image', function() {
  expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.0.jpg');
 });

 it('should swap main image if a thumbnail image is clicked on', function() {
  element('.phone-thumbs li:nth-child(3) img').click();
  expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.2.jpg');

  element('.phone-thumbs li:nth-child(1) img').click();
  expect(element('img.phone').attr('src')).toBe('img/phones/nexus-s.0.jpg');
 });
 });
});

你现在可以刷新你的浏览器,然后重新跑一遍端到端测试,或者你可以在AngularJS的服务器上运行一下。

练习

为PhoneDetailCtrl添加一个新的控制器方法:

$scope.hello = function(name) {
  alert('Hello ' + (name || 'world') + '!');
 }

并且添加:

 <button ng-click="hello('Elmo')">Hello</button>

phone-details.html模板。

总结

现在图片浏览器已经做好了,我们已经为步骤11(最后一步啦!)做好了准备,我们会学习用一种更加优雅的方式来获取数据。

以上就是AngularJS 事件处理器的资料整理,后续继续补充,谢谢大家对本站的支持!

Javascript 相关文章推荐
火狐4、谷歌12不支持Jquery Validator的解决方法分享
Jun 20 Javascript
artdialog的图片/标题以及关闭按钮不显示的解决方法
Jun 27 Javascript
js hover 定时器(实例代码)
Nov 12 Javascript
Javascript基础教程之while语句
Jan 18 Javascript
基于Bootstrap实现Material Design风格表单插件 附源码下载
Apr 18 Javascript
javascript和jQuery实现网页实时聊天的ajax长轮询
Jul 20 Javascript
浅析$(function) ready和onload 的区别
Sep 03 Javascript
微信小程序实战之登录页面制作(5)
Mar 30 Javascript
vue内置指令详解
Apr 03 Javascript
vscode配置vue下的es6规范自动格式化详解
Mar 20 Javascript
使用Node.js写一个代码生成器的方法步骤
May 10 Javascript
js表达式与运算符简单操作示例
Feb 15 Javascript
jQuery增加、删除及修改select option的方法
Aug 19 #Javascript
浅谈jquery设置和获得checkbox选中的问题
Aug 19 #Javascript
AngularJS入门教程之过滤器详解
Aug 19 #Javascript
js判断checkbox是否选中个数的方法(超简单)
Aug 19 #Javascript
Angular设置title信息解决SEO方面存在问题
Aug 19 #Javascript
js仿腾讯QQ的web登陆界面
Aug 19 #Javascript
基于WebUploader的文件上传js插件
Aug 19 #Javascript
You might like
24条货真价实的PHP代码优化技巧
2016/07/28 PHP
PHP性能测试工具xhprof安装与使用方法详解
2018/04/29 PHP
PHP自定义错误处理的方法分析
2018/12/19 PHP
php连接sftp的作用以及实例代码
2019/09/23 PHP
prototype 的说明 js类
2006/09/07 Javascript
Area 区域实现post提交数据的js写法
2014/04/22 Javascript
javascript 实现 原路返回
2015/01/21 Javascript
js实现分享到随页面滚动而滑动效果的方法
2015/04/10 Javascript
用javascript实现自动输出网页文本
2015/07/30 Javascript
javascript解决小数的加减乘除精度丢失的方案
2016/05/31 Javascript
AngularJS教程之MVC体系结构详解
2016/08/16 Javascript
Angularjs的Controller间通信机制实例分析
2016/11/07 Javascript
对VUE中的对象添加属性
2018/09/18 Javascript
基于layui的下拉列表的数据回显方法
2019/09/24 Javascript
js判断在哪个浏览器打开项目的方法
2020/01/21 Javascript
基于javascript canvas实现五子棋游戏
2020/07/08 Javascript
vue界面发送表情的实现代码
2020/09/11 Javascript
[02:04]完美世界城市挑战赛秋季赛报名开始 谁是solo路人王?
2019/10/10 DOTA
python编写网页爬虫脚本并实现APScheduler调度
2014/07/28 Python
Python的Flask框架应用程序实现使用QQ账号登录的方法
2016/06/07 Python
python发送邮件功能实现代码
2016/07/15 Python
解决Python 遍历字典时删除元素报异常的问题
2016/09/11 Python
Python使用剪切板的方法
2017/06/06 Python
Python实现数据结构线性链表(单链表)算法示例
2019/05/04 Python
Python2.7实现多进程下开发多线程示例
2019/05/31 Python
Python读取yaml文件的详细教程
2020/07/21 Python
Flask处理Web表单的实现方法
2021/01/31 Python
基于CSS3实现的黑色个性导航菜单效果
2015/09/14 HTML / CSS
canvas使用注意点总结
2013/07/19 HTML / CSS
澳大利亚家庭花园和DIY工具网店:VidaXL
2019/05/03 全球购物
YSL圣罗兰美妆英国官网:Yves Saint Laurent Beauty UK
2019/08/03 全球购物
机械设计及其自动化求职推荐信
2014/02/17 职场文书
团队队名口号大全
2014/06/06 职场文书
催款函范文
2015/06/24 职场文书
交通安全学习心得体会
2016/01/18 职场文书
React实现动效弹窗组件
2021/06/21 Javascript