(1)我有一个名为portlet
的转录指令,它将其内容包装在一些样板代码中。 E.g:
<portlet>
<div class="foobar">My content</div>
</portlet>
浏览portlet
的模板,即:
<div class="portlet">
<div class="icon"></div>
<div class="content" ng-transclude="">
</div>
</div>
变成:
<div class="portlet">
<div class="icon"></div>
<div class="content">
<div class="foobar">My content</div> <!--the original content
passed to portlet-->
</div>
(2)我还有两个指令dyn-form
和dyn-form-field
。用这种方式描述:
<dyn-form>
<dyn-form-field type="textbox" placeholder="..." label="Name" />
<! ...and so on... -->
</dyn>
dyn-form
的模板:
<form class="..." ng-transclude="">
</form>
每个dyn-field
的模板都会生成html,用于为其生成标签/字段。所以原始代码被翻译成这样的东西:
<form class="...">
<label>Name: <input type="text" placeholder="..." /></label>
<!- ....and so on... -->
</form>
(3)这是问题所在。我想使用第三个指令dyn-form-portlet
来生成样板代码,用于显示每个表单上方显示的一些按钮,然后显示一个portlet,并将dyn-form
放在portlet中。这就是我试图这样做的方式:
<dyn-form-portlet>
<dyn-form>
<dyn-form-field />
</dyn-form>
</dyn-form-portlet>
dyn-form-portlet
的模板如下所示:
<div class="dyn-form-portlet">
<button>Foo</button>
<button>Bar</button>
<portlet ng-transclude="">
</portlet>
</div>
理论上这应该有效,即<dyn-form>
应放在<portlet>
内,<dyn-form-field>
内<dyn-form>
内,依此类推。但是当我运行此功能时,我只看到dyn-form-portlet
显示的按钮和portlet
的代码,但portlet
为空,表单未显示在其中。
我做错了什么,或者这是一个错误?
答案 0 :(得分:5)
我设法解决了这个问题。我在transclude : 'element'
指令上使用replace : true
和portlet
,并且比其他指令高priority
。我这样做的原因是感觉而不是对内部工作的深刻了解。
关于第一部分
使用transclude : 'element'
是因为
'element' - 转换整个元素,包括以较低优先级定义的任何指令。
使用替换是因为从我所看到的,当transclude设置为element时总是使用它。 优先是我的预感。
这是plnkr http://plnkr.co/edit/axQ90dHOLmLNeNQ4ZlNl?p=preview
这可能不是您正在寻找的答案,但我需要深入研究角度指令才能真正了解正在发生的事情。无论如何,这不是一个错误,它只是糟糕的文档。