AngularJS in Action读书笔记6(实战篇)——bug hunting

时间:2022-08-31 23:41:15

  这一系列文章感觉写的不好,思维跨度很大,原本是由于与《Angularjs in action》有种相见恨晚而激发要写点读后感之类的文章,但是在翻译或是阐述的时候还是会心有余而力不足,零零总总的写了《Angularjs in action》读书笔记的前三篇。渐渐明白,将新知识搞懂是一门本事,而将自己明白的share出去并让别人也明白更是一门学问。几篇翻译下来,感觉有些苍白,有网友给建议说是真枪实战的做点东西,结合代码更有说服力。想想也是,纸上得来终觉浅,绝知此事要躬行。于是乎就有了《Angularjs in action》读书笔记(实战篇)这一系列的文章。谨以此系列来对过去的工作和感悟做了一些记录。对于新增的statistic模块的实现也基本到此结束,目前实现的功能:

1.数据统计

  可以选择指定的用户,并对当前选择的用户下的status的条目进行统计,比如在TODO阶段的有几条,在InProgress阶段的又有几条。

2.图形统计

  (1)图形统计设置有开关,可以选择显示/隐藏

  (2)图形统计-饼状图,可以选择饼状图可视化显示,图形会展示每个statu所占的比例和对应的statu名称,支持tooltip功能

  (3)图形统计-柱状图, 可以选择柱状图可视化显示,图形会展示每个statu的数量,可以清晰的看到那个statu的条数最多/最少

  效果如下:

  a.默认不显示可视化统计结果

AngularJS in Action读书笔记6(实战篇)——bug hunting

  b.点击show(默认显示饼状图)或者点击Pie chart按钮后

AngularJS in Action读书笔记6(实战篇)——bug hunting

  c.点击Bar Chart后

AngularJS in Action读书笔记6(实战篇)——bug hunting

  d.点击Hide按钮后

  效果如a所示。

  这篇主要是bug hunting主题,主要就是解决下编码过程中出现的一些bug。

  继上篇来说看似页面能够展示可视化结果以及数据信息,但是在实际操作中还是会发现一些问题:

1.svg图形重复创建

  bug:点击statistic按钮进入statistic模块,点击用户对应的统计按钮后,会弹出数据和图形统计信息,在不刷新页面的情况下,点击返回或进入其他模块,之后再回到这个统计页面,就会发现这里出现了两个统计图形,重复上面的操作,每次都会增加一个统计图形。

  hunting:查看代码发现,只要进入统计页面,系统不会判断直接又创建一个svg标签并绑定到body上。

  解决的方法就是在进入这个页面的时候对svg做一个判断,当svg的超过1时,就不再执行创建svg和显示svg的代码

angular.module("Angello.Statistic").directive(
"d3chart",
function() {
return {
restrict : 'EA',
scope : {
stories : "=",
statusArr : "="
},
link : function($scope, $element, $attrs) {// link or controller
var width = 400;
var height = 400;
var dataset = $scope.statusArr;
if($("svg").length >= 1){ //if exist svg in html source code return, else create
return;
}else{
var svg = d3.select("body").attr("align", "center")// align svg to center
.append("svg").attr("width", width).attr("height", height);
var pie = d3.layout.pie();
var piedata = pie(dataset);
var outerRadius = 150; // 外半径
var innerRadius = 0; // 内半径,为0则中间没有空白
var arc = d3.svg.arc() // 弧生成器
.innerRadius(innerRadius) // 设置内半径
.outerRadius(outerRadius); // 设置外半径
var color = d3.scale.category10();
var arcs = svg.selectAll("g").data(piedata).enter()
.append("g").attr(
"transform",
"translate(" + (width / 2) + ","
+ (width / 2) + ")");
arcs.append("path").attr("fill", function(d, i) {
return color(i);
}).attr("d", function(d) {
return arc(d);
});
arcs.append("text").attr("transform", function(d) {
return "translate(" + arc.centroid(d) + ")";
}).attr("text-anchor", "middle").text(function(d) {
return d.data;
});
console.log(dataset);
console.log(piedata);
} } // }
}
});

  这里的$("svg")是JQuery的语法,意为找到标签名为svg的集合。

2.脏数据显示

  bug:当从统计页面的statistic模块切换到其他模块如dashboard后,仍然可以看到饼状图作为背景显示在dashboard的页面背景中。这是一个脏数据。

  hunting:这时候最容易想到需要使用的就是ng-if,所以想到用ng-if来控制这个div也就是d3chart这个指令的显示。一开始的思路是

<div ng-if="myUser.existed"  status-arr="myUser.statusArr" d3chart></div>

  直接通过ng-if控制,然后在DataController中为myUser.existed赋值为true,然后想着在directive中将这个myUser.existed置为false,但是一直为这个existed如何注入到directive中并进行赋值所困扰,几经周折放弃了这个想法,想到了个间接的解决方案

<div ng-if="myUser.existed">
<div existed="myUser.existed" status-arr="myUser.statusArr" d3chart></div>
</div>

  通过上层的div来控制里面div的显示,然后在里面div写成existed="myUser.existed"的形式绑定到directive的scope中实现赋值。
  这个思路应该是没有问题的,但是在实操过程中,还是没能解决问题。仔细一想是因为在directive中原来的代码是这样的:

link : function($scope, $element, $attrs) {// link or controller
var width = 400;
var height = 400;
var dataset = $scope.statusArr;
if($("svg").length >= 1){ //if exist svg in html source code return, else create
return;
}else{
var svg = d3.select("body").attr("align", "center")// align svg to center
.append("svg").attr("width", width).attr("height", height);
var pie = d3.layout.pie();
var piedata = pie(dataset);
                                 ....

  

  这段代码意思是将svg的标签append到body下面,这与data.html中的div是平级,所以又改造了这里的代码为:

link : function($scope, $element, $attrs) {// link or controller
var width = 400;
var height = 400;
var dataset = $scope.statusArr;
if($("svg").length >= 1){ //if exist svg in html source code return, else create
return;
}else{
// d3.select("body").attr("align", "center");
var svg = d3.select(".flag").attr("align", "center")// align svg to center and move svg into div
.append("svg").attr("width", width).attr("height", height);
var pie = d3.layout.pie();
var piedata = pie(dataset);

  

  这样dom中的层级结构就是svg是包在div里面的。就实现了ng-if对于这个div的操作会影响到svg的显示,否则按照原来的代码,ng-if只能管到div的显示,而div与svg平级,所以svg并不受影响。

  这样一来,就能够完成在directive中修改myUser.existed的值了。使得在不同模块切换过程中不会残留statistic中的图形显示了。

  关于如何添加柱状图Bar Chart支持、如何添加悬浮信息提示框、如何显示图形对应模块的名称而不是数字等问题可以参看代码,这里以及后面就不再贴代码,详情点击这里

  如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!如果您想持续关注我的文章,请扫描二维码,关注JackieZheng的微信公众号,我会将我的文章推送给您,并和您一起分享我日常阅读过的优质文章。

  AngularJS in Action读书笔记6(实战篇)——bug hunting

友情赞助

如果你觉得博主的文章对你那么一点小帮助,恰巧你又有想打赏博主的小冲动,那么事不宜迟,赶紧扫一扫,小额地赞助下,攒个奶粉钱,也是让博主有动力继续努力,写出更好的文章^^。

    1. 支付宝                          2. 微信

AngularJS in Action读书笔记6(实战篇)——bug hunting                      AngularJS in Action读书笔记6(实战篇)——bug hunting

AngularJS in Action读书笔记6(实战篇)——bug hunting的更多相关文章

  1. AngularJS in Action读书笔记4&lpar;实战篇&rpar;——创建Statistic模块

    个人感觉<Angularjs in action>这本书写的很好,很流畅,循序渐进,深入浅出,关键是结合了一个托管于Github上的实例讲解的,有代码可查,对于初学者应该是个不错的途径.( ...

  2. AngularJS in Action读书笔记5&lpar;实战篇&rpar;——在directive中引入D3饼状图显示

    前言: "宁肯像种子一样等待  也不愿像疲惫的陀螺  旋转得那样勉强" 这是前几天在查资料无意间看到的一位园友的签名,看完后又读了两遍,觉得很有味道.后来一寻根究底才知这是出资大诗 ...

  3. AngularJS in Action读书笔记1——扫平一揽子专业术语

    前(fei)言(hua): 数月前,以一个盲人摸象的姿态看了一些关于AngularJS的视频书籍,留下了我个人的一点或许是指点迷津或许是误人子弟的读后感.自以为已经达到熟悉ng的程度,但是因为刚入公司 ...

  4. AngularJS in Action读书笔记2——view和controller的那些事儿

    今天我们来818<angularjs in action>的第三章controller和view. 1.Big Picture概览图 View是angularjs编译html后呈现出来的, ...

  5. AngularJS in Action读书笔记3——走近Services

    试着想想这些问题:如果一个controller只关心自己所控制的view页面,那么对于整个application来说,你如何调用想要的function:如果controller从来都不会和其他cont ...

  6. AngularJS高级程序设计读书笔记 -- 大纲篇

    零. 初衷 现在 AngularJS 4 已经发布了, 楼主还停留在 1.x 的阶段, 深感自卑. 学习 AngularJS 的初衷是因为, 去年楼主开始尝试使用 Flask 开发自动化程序, 需要用 ...

  7. AngularJS高级程序设计读书笔记 -- 指令篇 之 内置指令

    1. 内置指令(10-12 章) AngularJS 内置超过 50 个内置指令, 包括 数据绑定,表单验证,模板生成,时间处理 和 HTML 操作. 指令暴露了 AngularJS 的核心功能, 如 ...

  8. AngularJS高级程序设计读书笔记 -- 服务篇

    服务是提供在整个应用程序中所使用的任何功能的单例对象. 单例 : 只用一个对象实例会被 AngularJS 创建出来, 并被程序需要服务的各个不同部分所共享. 1. 内置服务 一些关键方法也被 Ang ...

  9. AngularJS高级程序设计读书笔记 -- 过滤器篇

    一. 过滤器基础 过滤器用于在视图中格式化展现给用户的数据. 一旦定义过滤器之后, 就可在整个模块中全面应用, 也就意味着可以用来保证跨多个控制器和视图之间的数据展示的一致性. 过滤器将数据在被指令处 ...

随机推荐

  1. 按Enter键执行表单验证

    document.onkeydown = function(evt){ var evt = window.event?window.event:evt; if (evt.keyCode==13) { ...

  2. &period;NET 4&period;5 WPF Ribbon

    文/嶽永鹏 Visual Studio 2012  DO.NET 4.5 Ribbon 界面编程. 代码 =============================================== ...

  3. CKEditor和IMCE构建drupal编辑器

    1. 安装并启用CKEditor和IMCE模块. 2. 配置CKEditor: 3. 配置用户的权限即可.最终效果图:

  4. J2EE(java)后台调用ArcGIS Engine(AE)的部署和代码

    arcgis的BS开发解决方案一直是个坑,主推的地图服务查询速度慢,需要异步,功能少.相对来说主要用于CS的AE功能更强大全面,只是部署有点复杂 本文软件环境: win7 sp1 64位 MyEcli ...

  5. vector 利用swap 函数进行内存的释放 vector&lt&semi;int&gt&semi;&lpar;&rpar;&period;swap

    首先,vector与deque不同,其内存占用空间只会增长,不会减小.比如你首先分配了10,000个字节,然后erase掉后面9,999个,则虽然有效元素只有一个,但是内存占用仍为10,000个.所有 ...

  6. &lbrack;国嵌攻略&rsqb;&lbrack;108&rsqb;&lbrack;Linux内核链表&rsqb;

    链表简介 链表是一种常见的数据结构,它通过指针将一系列数据节点连接成一条数据链.相对于数组,链表具有更好的动态性,建立链表时无需预先知道数据总量,可以随机分配空间,可以高效地在链表中的任意位置实时插入 ...

  7. CSS如何把一张横向的长图变成竖向的?

    前言: 有时候做项目过程中,设计的是一张横向的长图,但是我们需要在手机端观看的时候,也想把手机横着观看,这样视野更宽阔,如何解决这个问题呢? html <div class="imgB ...

  8. 帆软报表(finereport)参数组合&sol;下拉参数联动

    首先实现下拉参数联动 1.参数的定义→添加控件绑定数据→参数过滤和参数面板样式 下拉复选框控件注意事项:select * from tablewhere 1=1${if(len(控件名称)=0,&qu ...

  9. Linux下的快捷键

    1:tab 键 命令补全 路径补全 2:Ctrl+C    命令的中止 3:Ctrl+D     退出当前的会话  exit   logout 4:Ctrl+l      clear  清屏    5 ...

  10. 作业六:小学生四则运算之NABCD模型与产品Backlog。

    NABCD模型与产品Backlog NABCD模型 ) N (Need 需求) 方便了老师和学生,使他们可以想要的时候随时可以得到,省时省力,快速出题,马上得到答案. ) A (Approach 做法 ...