- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在尝试维护 DRY 概念时遇到了 AngularJS 的问题 [不要重复自己]。我希望我做错了什么,有人可以指出我的错误。
一家公司销售卡车和汽车。 这两个项目具有相似和不同的属性。添加到其中一种的库存时需要一些表单,而另一种则不需要,因此看来我必须创建两种表单,一种用于卡车和汽车。好吧,没问题。但这是我感到困惑的地方。
卡车和汽车都有一个称为传输的属性,因此我更愿意创建一个"template"来添加传输类型,并通过 ng-include 将其嵌入“添加卡车”和“添加汽车”表单中。但因为我使用的是 ng-include,模板本身不在主表单的范围内,我需要限定它的 ng-model。
如果我在传输模板的输入中使用它:ng-model="newTruck.Tramission",添加新卡车的表单将其包含在范围内并且工作正常,但显然不是汽车我也想分享这个模板。所以我想使用这个: ng-model="$parent.Transmission" 这样模板就可以由任何一种形式使用,但这不起作用。
这可能会导致不必要的臃肿网站,即 StockNumber 模板、内部、外部颜色模板等......
那么,我需要违反 DRY 并为每个具有此类属性的不同产品使用相同的模板(例如“添加传输”模板),这是否正确,还是我做错了什么?
编辑:如果我没有说清楚的话,传输是汽车和卡车的关联类,而不是原始属性。
最佳答案
我认为 ng-init 内置于 Angularjs 中,就是针对这种情况。根据您提到的内容,我将假设您有两种对象,但这些对象的部分内容将是相同的(类似于 mixin)。
因此,您将有一个名为 Car
的类和一个名为 Truck
的类,但这两个类都包含一个名为 transmission
的对象,该对象是用户将在 ng-include 中编辑的内容。为了在 ng-include
中编辑相同的传输对象并使 Controller 不知道 transmission
的父对象,您定义一个契约怎么样?
<div ng-controller="CarCtrl">
<div>{{car.name}}</div>
<div ng-include="'transmission.html'" >
</div>
</div>
<div ng-controller="TruckCtrl">
<div>{{truck.name}}</div>
<div ng-include="'transmission.html'">
</div>
</div>
现在,您的 transmission.html
将如下所示:
<div class="transmission" ng-controller="TransmissionCtrl">
<!-- you want to be able to do model.transmission.type in here and be agnostic of whether model is car or truck-->
{{model.transmission.type}}
</div>
现在,ng-init
魔法来了。
只需将 ng-init="model = car"
添加到与 ng-include
相同的级别即可。
<div ng-controller="CarCtrl">
<div>{{car.name}}</div>
<div ng-init="model = car" ng-include="'transmission.html'" >
</div>
</div>
所以现在您的 TransmissionCtrl
不知道它正在编辑其传输的模型。干燥?
关于AngularJS 和 DRY,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15416959/
我是 DRY principle 的坚定拥护者: Every piece of knowledge must have a single, unambiguous, authoritative rep
假设我有一个稍微复杂的 for 循环,用于不同的情况。有没有一种方法可以提取该 forloop 并仍然保持代码可读性? 例如: private function bar(){ for(i=0;
JSData 是替代还是补充 Sequelize.js? 我试图了解这两个库如何一起玩以及是否应该一起玩。 从我的阅读来看,JSData 主要处理访问数据,而 Sequelize.js 将创建和修改
我有 aws-eks 集群,下面是我替换现有配置的命令。 kubectl create configmap flink-config --from-file=./config -o yaml --dr
我正在设计一个可重用的类库,其中包含 2 个名为 core.xml.dll 和 core.string.dll 的程序集(其中包括)。 xml 程序集引用字符串程序集,以便使用一些字符串辅助方法。 但
我正在尝试找到一种更 DRY 的方式来使用 docker-compose env。 docker-compose-base.yml base: image: reactjs_web v
我有一些看起来像这样的类(class): struct A { void *stuff; int x; int foo() const; } 我有一些采用这种类型参数的函数,例如 int
我目前正在 Silverlight 中构建一些自定义控件。我希望这些控件能够响应验证错误。我想要做的是在我的控件周围设置红色边框,就像默认的 Silverlight 控件一样。 我的理解是我需要将它添
我正在处理一些服务器端代码,在将它们传递给客户端之前包装所有异常,因此所有面向客户端的方法都有以下代码 try{ DoSomething(); } catch (ExceptionA e) {
“纵深防御”原则指出,应该在多个地方实现约束,这样如果一条数据绕过或漏过一层,就会在下一层被捕获。一个很好的例子是在网络应用程序中——你将验证放在客户端 javascript 中,放在服务器端代码中(
使用这种方法在 MVC 中查看模型:http://www.lostechies.com/blogs/jimmy_bogard/archive/2009/06/29/how-we-do-mvc-view
我想将 jquery 脚本优化为多个元素(单个页面上有许多幻灯片)。我可以添加一些功能,但这并不干燥(不要重复自己)。 Pr
我有一些代码(不是我的),其中包含带有声明的范围映射的指令。我的愿望是在其他地方使用该指令并传递将在模板中使用的附加变量。 我要传递的变量是theVar。 我发现唯一可行的解决方案看起来很噩梦:
我将数据存储在数组中,并从该数组中使用循环创建表。对于一个表,我需要两列,另外 30 列(取决于数组项)。这将有三列。 var prodej = [ /*First column, second,
有没有更好的方法来声明来自同一组(例如“com.android.support”)具有相同版本(例如“23.4.0”)的多个软件包(例如“appcompat-v7”)? 实际申报: ... def a
我有一个看起来像这样的对象: var myObj = { _fooCon: function(f) { if (typeof f != 'function') throw
这就是我所拥有的。 Map data = new HashMap<>(); // assume this has been populated public int getLastestVersion
我在尝试维护 DRY 概念时遇到了 AngularJS 的问题 [不要重复自己]。我希望我做错了什么,有人可以指出我的错误。 一家公司销售卡车和汽车。 这两个项目具有相似和不同的属性。添加到其中一种的
我最终在几个类中得到了几个遵循相同模式的方法(每个类中总是有一堆这些方法): private void updateFoo() { String newFoo = fooTextField.g
假设我有一个字典config,其中包含键username和password。我想创建一个新字典,仅包含 config 中的username 和 password 键值对。一种方法是: new_dict
我是一名优秀的程序员,十分优秀!