Passing data from one route view to another

前端 未结 3 898
情深已故
情深已故 2021-01-24 18:19

I want to pass some values from one view to another in Angularjs using ui-Router.
I don\'t want to use $rootScope to save data or create a new services ( as I have many view

相关标签:
3条回答
  • 2021-01-24 18:57

    Since you have specified the approach that you wanted to follow, you should create the following

    $stateProvider
        .state('view2', {
            url: "/view2/:param1/:param2",
            templateUrl: 'view2.html',
            controller: function ($stateParams) {
                console.log($state.params.param1+"-"+$state.params.param2);
            }
        });
    

    and from where ever you want to call

    $state.go('view2',{param1:'10', param2:'2'});
    

    But in general it is advised that you keep these values in a service or some where stored. With the application growing you may have to use few more attributes to compute

    0 讨论(0)
  • 2021-01-24 19:00

    I don't want to use $rootScope to save data or create a new services ( as I have many views that pass small bits of data so creating new jsfile for few lines code is not fun)

    There is no need to create a new service for new bits of data. Simply create a value service with an object:

    app.value("viewData", {});
    

    Then simply add new properties as needed:

    app.controller("viewCtrl", function(viewData) {
        viewData.newProp = "new info";
        console.log(viewData.oldProp);
    });
    

    As value services are singletons, changes to the contents of the object will survive view changes.

    0 讨论(0)
  • 2021-01-24 19:06

    Easiest way would be to store all the data directly into the $routeParams either through route or query string.

    routeUrl: /foods/:quality/:stars
    

    then in your controller you can access

    $routeParams.quality - $routeParams.stars
    
    0 讨论(0)
提交回复
热议问题