party_bid转眼间就做到了重构这一步,从刚开始的小白,到现在的半小白,还是有点小感慨的。。。这不是日记,就不瞎扯了,还是说说正题吧,接触angularJS已经一个月了,重构做完了,第一个小的作业也就算是告一段落了,现在写一些自己这段时间案来的理解,因为是边做party_bid边学习,自己理解的会多一些,希望看到的前辈们多指正!
一、我理解的重构应该算是angulaMVC模型的具体体现,model只是实现数据的增删改查,他不用去考虑这些数据如何显示、如何调用,他实现的只是最基本的数据操作;view实现的是图形界面的设计和显示;controller则是负责数据与请求的调用和处理,他会实现一些数据处理上的逻辑。
二、在重构之前,我写的代码可以说完全就是面向过程的,没有加入一点面向对象的思想,好吧,其实是那会儿我还不知道面向对象的思想是怎么个意思。。。等到了重构这一步,通过了解,才知道重构就是把面向过程的代码转化为面向对象的。通过调用model中的方法,简单明了的让读代码的人了解到整个代码的意思和结构,达到看者皆懂的目的。
面向对象的做法,其实就是按照“把复杂问题化简为单个的小问题”一般性工作思路,将程序要解决的问题切分为相对独立的实体,已达到理清其中关系明确任务边界的目的。
三、prototype属性
因为之前没有用过这个方法,所以在网上了解了一下,通过对多篇博客文章的综合和自己的理解,大概可以认为prototype这个属性类似于JAVA中的类继承,但是没有父类与子类的区分。在JS中,prototype的用途是向对象添加属性和方法,实现了一种类似于对实例化对象的继承
<script type="text/javascript"> function employee(name,job,born) { this.name=name; this.job=job; this.born=born; } var bill=new employee("Bill Gates","Engineer",1985); employee.prototype.salary=null; bill.salary=20000; document.write(bill.salary); </script> 输出: 20000
四、在将之前面向过程的方法抽成model后,自己常常犯的错误就是忘了传参数,从而导致好多时间都因为这个浪费在了查看代码逻辑上。。。。
五、$scope的用法
在我看来,scope起得作用就是JS双向绑定机制中的中间桥梁,我把它看成一个容器,他可以将controller中的scope作用域呈现给view或者model,也可以将view中所需要渲染传递的值放到容器中,呈现给controller中的逻辑方法进行调用,例如:
view: ul 竞价结果:{{winner_name}} {{winner_price}} {{winner_phone}} controller: jj_analyze($scope) model: j_analyze = function ($scope) { Bids.messages_bid() if (Bids.messages_bid()) { $scope.title = Bids.messages_bid().bid $scope.number = Bids.messages_bid().messages.length $scope.middle = Bids.price_number() judge_jj_people_number($scope) } }
上面代码同样运用到了function的参数传递
放上一个链接,便于大家共同学习关于$scope的内容:
http://blog.segmentfault.com/chao2/1190000000361245
可能是由于这是我接触编程以来第一次重构,还是有好多地方不能理解,还是希望以后多几次经验,把工作做得更好吧!
相关推荐
数据格式 uid_score_bid 如 dingdanglbh,4.0 ,25862578 Luna-cat,5.0 ,25862578 aiyung,5.0 ,25862578
9点潮流计算PSO的优化算法 很简单,只要在MATLAB运行就可以
欧美1分钟历史数据,2003年5月到2019年2月,MT4EA回测好用。
Repaso_Clases_Objetos_call_aplly_bid_22_02_2021
去噪代码 matlab
mc_bid
crc-16的编码,使用的多项式是G(x)=x^16+x^12+x^5+1
backup_1000821v1001400000.zip
附加服务器 欢迎使用Addons Server存储库! 请随时访问托管的当前项目的网页。 如果要安装,请遵循 指南。 我们希望您的帮助! 如果您有任何疑问,可以通过与我们联系。 请在此处报告错误: : 或您可以通过访问AMO...
bid0-lid0-steam游戏管家_steambdth01_1.0.0.1487@1prw2r@gog.exe
出价统计信息和详细信息 作为签约过程一部分而...bids.details数组用于提供一个或多个Bid对象,每个对象代表收到的唯一出价。 bids.statistics数组用于表示有关投标和投标者数量的关键统计信息。 数组中的每个条目都
bid0-lid64-steam.game_steamzc9_2.0.0.2702.exe.file
Bid Documents - Toyota Hilux Fx
bid0-lid64-steam.game_steamzc_2.0.0.2242.exe
演示脚本:Demo_BID_PnP.m%========================================== ========================% 接触: Marina Ljubenovic-葡萄牙里斯本电信研究所- Mario AT Figueiredo-葡萄牙里斯本电信学院-%============...
VHDL语言编写,实现双向移位寄存器功能,在MAX+plus软件下实现
为什么使用简单有效的二进制文件格式:密集刻度格式(DTF) 存储形状为:( (timestamp, seq, is_trade, is_bid, price, size)订单簿(timestamp, seq, is_trade, is_bid, price, size)数据元组。 按时间戳+ seq排序...
bid格式招投标文件阅读器,可以打开浏览、管理电子招标文件,如果打不开标书文件,请按下面步骤检查:1、请查看招标文件(.bid文件)是否下载完全,请用IE下载工具下载;2、查看IE浏览器版本,如果版本低于IE8,低于IE...
create index book_bid_idx on book(bid); create index abc on student(sid,sname); create index abc1 on student(sname,sid);他们是不同的 2、查看索引 select index_type,index_name,table_name,uniqueness from...
mining_bid_data Hadoop