What is the best way to pass functions between inner components in AngularJS 1.5?

后端 未结 1 1306
没有蜡笔的小新
没有蜡笔的小新 2021-02-14 02:48

I was wondering what is the best way to pass functions down through 2 or more levels of components? There\'s no simple way of skipping the function wrap when using \'&\' bin

相关标签:
1条回答
  • 2021-02-14 03:23

    It is not necessary to provide a wrapper function in the controller of your sub-components. By using bindings a function is automatically attached to the controller, which you can call directly from your template.

    The only wrinkle is that this function takes an object, which contains the locals that will be made available to the expression in the outer template.

    In this case the data variable in the outer template needs to be provided explicitly when call the the doSomething(locals) method.

    angular.module('app', [])
    
    .component('app', {
      controller: class AppController {
        doSomething (data) {
          console.log(data);
        }
      },
      template: `
        <sub-component do-something="$ctrl.doSomething(data)">
        </sub-component>
      `
    })
    
    .component('subComponent', {
        bindings: {
            doSomething: '&'
        },
        template: `
            <inner-component do-something="$ctrl.doSomething({data: data})">
            </inner-component>
        `
    })
    
    .component('innerComponent', {
        bindings: {
            doSomething: '&'
        },
        template: `
            <sub-inner-component do-something="$ctrl.doSomething({data: data})">
            </sub-inner-component>
        `
    })
    
    .component('subInnerComponent', {
      bindings: {
        doSomething: '&'
      },
      template: `
          <button ng-click="$ctrl.doSomething({data: 123})">Do Something</button>
      `
    });
    

    Here is a working Plunker : http://plnkr.co/edit/QQF9jDGf6yiewCRs1EDu?p=preview

    0 讨论(0)
提交回复
热议问题