位置: 编程技术 - 正文

AngularJS中controller控制器继承的使用方法

发布时间:2024-02-27

推荐整理分享AngularJS中controller控制器继承的使用方法,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

前沿

最近在angularjs项目当中,看到 controller 好多都是重复性的代码,在 controller 当中有好多代码很相似 function(比如 controller 下的 CRUD 方法),重复性工作太多。后来想,可不可以提出一个service ,但仔细想想,这些CRUD 本来就是从 Service 中调用的,如果在提出Service,会造成 Service 比较混乱,职责不清晰 。 因为自己做过一些后端,借助后端的思想,是不是可以 controller 继承。

controllerservice实现继承经过一番查阅资料,发现AngularJS已经帮我们提供了controller继承。我们只需借助 controllerservice 。$controller service api

嵌套控制器中属性是如何被继承的?

==属性值是字符串

以上,ParentCtrl中的name字段被ChildCtrl分享,但改变ChildCtrl中的name字段值却不会影响ParentCtrl中的name值,当改变ChildCtrl中的name值,ParentCtrl和ChildCtrl的嵌套关系被打破,再次改变ParentCtrl中的name字段值也不会影响ChildCtrl中的name值。

以上,给ParentCtrl中的变量赋值是字符串类型,如果给ParentCtrl中的字段赋值对象类型呢?

==属性值是对象

以上,ParentCtrl中vm对象的被ChildCtrl分享,当然也分享了对象中的name字段,当改变ChildCtrl中的vm.name值会影响到ParentCtrl,也就是不会把ParentCtrl和ChildCtrl之间的嵌套关系打破。

AngularJS中controller控制器继承的使用方法

嵌套控制器中方法是如何被继承的?

使用ArrayCtrl中的add方法,添加没问题;而且ArrayCtrl中的add方法也可以被CollctionCtrl使用;

而且在子控制器中可以重写父控制器中的方法。

代码案例

1.创建一个 base.controller.js 文件

代码很简单,我们在 BaseController中提供了一个简单的 formValid() 方法,还初始化调用了一个getList() 方法。

2.创建一个Service 。这个 service 来提供数据服务

3.创建child.controller.js 文件 也就是我们最主要的一个文件

这样,我们通过 $controller service 实现了 controller 的继承 ,也可以把 child controller 需要的注入的服务 传入到 base controller 当中 。({ $scope, $scope,CRUDServices:ExtendServices }),我们child controlller 一行代码都没有写,就已经用了 获取 列表的 magic power 。如果我们需要调用表单验证,直接调用 vm.bFormValid() 就可以。

4.创建child.html 文件 ,我们直接 绑定就ok

结束语

这样下来以后我们可以提出一个 公共的 controller ,封装一些常用的方法,在 controller当中,只需要去写关于业务不同的 方法。 代码可维护性大大提高,代码量也会减下来。

标签: AngularJS中controller控制器继承的使用方法

本文链接地址:https://www.jiuchutong.com/biancheng/375857.html 转载请保留说明!

上一篇:vue解决跨域路由冲突问题思路解析(vue如何处理跨域)

下一篇:angular中ui calendar的一些使用心得(推荐)

  • 工资薪金和工资薪金总额区别
  • 代销返点怎么交税费
  • 小规模企业所得税多少
  • 升级10万元版发票有什么要求
  • 库存现金冲销
  • 只有费用没有收入成本怎么填所得税
  • 事业单位的股东是什么
  • 员工工资的扣点
  • 递延所得税费用影响净利润吗
  • 受赠人个人所得税
  • 固定资产直接进费用违背什么
  • 1697508857
  • 会计审核票据如何签字
  • 公司买手机给员工怎么做账
  • windows11家庭版本地策略组
  • 退回多收款项开具发票原发票需要退回吗
  • 退多收款怎么做分录
  • win10如何禁止
  • 拍卖获得收入个税
  • 罚款是否需要开发票
  • php curl_multi_init
  • 已确认坏账又收回账面价值会减少?
  • 营改增后土增税收入
  • php 文件系统
  • php面向对象的三大特征
  • 豁免债权如何做账
  • 同业拆入属于哪个行业
  • 小规模纳税人增值税免税政策
  • vue3 ref dom
  • css常见的选择器有哪几种
  • 前端开发工程师是干嘛的
  • php程序技术
  • 一般纳税人销售给小规模纳税人
  • 对公账户走账是怎么回事
  • 物流货运发票要交税吗
  • 净现值与原始投资额现值
  • 分公司非独立核算企业所得税处理
  • phpcms官网打不开
  • python中如何创建字典
  • python PyQt5如何实现窗口功能
  • 认缴制无实收资本怎么算
  • mysql的常用命令
  • MYSQL administrator 使用
  • 什么情况下企业亏损但继续生产
  • 消费税如何计量
  • 出纳属于会计岗位职责吗
  • 计算企业所得税可以扣除的税金
  • 出口货物免税的税种包括
  • 会计学中递延收益的概念
  • 计提工会经费是什么凭证
  • 外币转入账户什么意思
  • 应扣未扣税款对纳税人的处理
  • 公司赞助学校
  • 出口退税怎么回事
  • 现金日记账的日期怎么写
  • 旅游饮食服务企业财务会计制度
  • sqlserver 获取表字段
  • sql server 2000安装包
  • window 脚本
  • win10怎么进u盘系统
  • linux命令行查找
  • ezulumain.exe是病毒进程吗 ezulumain进程安全吗
  • win8安装界面
  • win1020h2更新卡在1
  • windows7的word
  • linux系统获取ip地址
  • [置顶]bilinovel
  • 安卓游戏模拟游戏制作
  • node.js如何运行
  • 基于javascript的论文题目
  • jquery解析html文本
  • Python 数据清洗
  • android基础入门教程
  • 用jquery
  • python代码规范化
  • python通过编程求权重
  • 东莞税务申报日期
  • 财产转让所得适用税率
  • 打税务局电话
  • 重庆市非住宅交易税费
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号