AngularJS:如何转换多个指令?

时间:2013-08-28 19:44:34

标签: javascript angularjs

(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-formdyn-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为空,表单未显示在其中。

我做错了什么,或者这是一个错误?

1 个答案:

答案 0 :(得分:5)

我设法解决了这个问题。我在transclude : 'element'指令上使用replace : trueportlet,并且比其他指令高priority。我这样做的原因是感觉而不是对内部工作的深刻了解。

关于第一部分 使用transclude : 'element'是因为

  

'element' - 转换整个元素,包括以较低优先级定义的任何指令。

使用替换是因为从我所看到的,当transclude设置为element时总是使用它。 优先是我的预感。

这是plnkr http://plnkr.co/edit/axQ90dHOLmLNeNQ4ZlNl?p=preview

这可能不是您正在寻找的答案,但我需要深入研究角度指令才能真正了解正在发生的事情。无论如何,这不是一个错误,它只是糟糕的文档。