angularJS自定义directive之带参方法传递详解
程序员文章站
2023-11-11 17:04:34
如下所示:
//自定义指令 "myemail"
grgapp.directive("myemail",function(){
return{
restr...
如下所示:
//自定义指令 "myemail" grgapp.directive("myemail",function(){ return{ restrict:'ae', scope:{todir:'@', fromname:'@', sendemail:'&' }, templateurl:'/htmls/main/html/custom/email.html',} }); //控制器中的方法 $scope.send=function(msg){ alert("send email! msg: "+msg); } //email.html <div style="width: 100%;height: 100%;color: white;font-size: 0.8rem;"> <label style="width: 100%;height: 15%;" ng-bind="todir"></label> <label style="width: 100%;height: 15%;" ng-bind="fromname"></label> <textarea style="width: 100%;height: 25%;color: black;" ng-model="content"></textarea> <button style="width: 10%;height: 15%;color: black;" ng-click="sendemail({msg:content})">提交</button> </div> //html调用 <my-email to-dir="广东中山" from-name="海南海口" send-email="send(msg)"/>
功能:点击【提交】后,将自定义指令myemail中textarea元素的内容传递给控制器中的send()方法。
关键点:模板email.html中的ng-click="sendemail({msg:content})" 参数{msg:content}必须是一个键值对,键为:方法参数名 值为:传递的内容
以上这篇angularjs自定义directive之带参方法传递详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。