찾다

 >  Q&A  >  본문

javascript - Angular利用 broadcast和 on实现页面跳转并且传递数据 但是跳转后收不到数据

我利用Angular中$broadcast和$on实现页面跳转并且传递数据,但是跳转后收不到数据(再次点击按钮才会显示)
具体要求:点击第一个页面的按钮,传递一个数组(如下图中的shopList数组)到第二个页面,使得第二个页面能够接收到shopList数组

第一个页面

<a ui-sref="app.checkOut" ng-click="checkoutShop(shopList)"><b>结算</b></a>

对应的controller(是主控制器-父级)

$rootScope.checkoutShop=function(shop){  
    var shop_list_data = shop;
    console.log(shop_list_data);
    $rootScope.$broadcast('to_checkout', shop_list_data);
};

第二个页面的controller(是主控制器下的子集)

$scope.$on('to_checkout', function(event,data) {  
    console.log(data);
});

但是测试后发现第二个页面的console.log(data)打印失败,但是再次点击又会成功,是路由的问题吗?具体如下:
主页面如下,购物车是隐藏在侧面的,点击导航栏中的购物车,右侧会出现购物车

刚开始:


点击按钮后,传递数组并且跳转到另外一个页面,但是并没有打印这个数组:


再次点击“结算”按钮,就会打印了:


请问这是什么原因?该如何解决呢?

高洛峰高洛峰2743일 전740

모든 응답(3)나는 대답할 것이다

  • 世界只因有你

    世界只因有你2017-05-15 17:16:25

    Remove ui-sref="app.checkOut", 메서드에서 먼저 $broadcast를 실행한 다음 점프를 라우팅합니다.

    으아악

    회신하다
    0
  • 大家讲道理

    大家讲道理2017-05-15 17:16:25

    rootScope 아래에 클릭 이벤트를 추가하는 이유는 무엇입니까? 페이지 범위에 직접 추가하고 살펴보세요.

    회신하다
    0
  • phpcn_u1582

    phpcn_u15822017-05-15 17:16:25

    $state.go는 페이지로 이동할 때 매개변수를 직접 전달할 수 있는데 왜 $broadcast

    를 사용해야 할까요?

    마스터 컨트롤러 - 상위

    으아악

    메인 컨트롤러 아래 하위 세트

    으아악

    회신하다
    0
  • 취소회신하다