Ir al contenido principal

AngularJS: Router

Router

  • Depends on angular-route.js
  • Rules are defined in $routeProvider
  • Normally defined in  app.js
  • $stateProvider is a better option



  • Create an index.html
    • Add the section <ng-view>  </ng-view>


  • In app.js file

var app = angular.module( "githubViewer", [ngRoute] );

app. config ( function ($routeProvider) {

        $routeProvider
                   .when("/main" , {
                            templateURL: "mypage.html",
  • The controller is optional, the other way is to include it in the html
                            controller: "MyController"              
                   })
  • Receiving paramenters
    • In the controller you have to use $routeParams to receive the parameters
      • var controller = function ($routeParams ){  -.....
      • param = routeParams.param1;
                      .when( "/user/:user", {
                                templateURL: "mypag2e.html",
                                controller: "MySecondController"


  • To wait until the data is fetch
                                resolve: {
                                       event : function($route, even){
                                                return even.getData().$promise;
                                          }

                                  }



                        })



                     .otherwise({redirection : "main.html"});

});


$route


  • Accesing paramenters through URL
URL:  index.html/4?paramenter=foo
$route.current.param.<parameter>   ( = foo)

$route.current.param.eventId   ( = 4)


$route.reload();


  • The references in the pages should be:   #/otherpage.html

Location


Use to move in the a specific part of the html page
  • In the controller you have to use $location to receive the parameters
    • var controller = function ($location ){  -.....
    • $location.path("/myPath/" + userName) ;


Move to another URL

$location..url('newURL')

Avoid the use of # in URL

  • Needs 'ngRoute'
$locationProvider.html5Mode({
enabled : true
});

  • Add in your main page
<base href="/index.html">



Get the string after #

  • location.hash()
  • Ex.- index.html/newEvent#quiz   (hash() = quiz)

Get Parameters

  • $location.search()
Replace in the history with the new pages

  • $location.replace()

  • $location.path()
  • $location.url()

ng-view

Section where the pages will be loaded








Comentarios

Entradas populares de este blog

C# Using tabs

To use tabs in C# use the TabContainer element from AjaxControlToolkit Include AjaxControlToolkit  Include in the Web.config file, inside the tag <system.web> the following code  <pages>       <controls>         <add tagPrefix="ajaxCTK" namespace="AjaxControlToolkit" assembly="AjaxControlToolkit"/>       </controls>     </pages>   Include TabContainer element First  include TabContainer element that is the section where all the tabs will be displayed. <ajaxCTK:TabContainer ID="TabContainerUpdate" runat="server"                 Height="800"                 CssClass="ajax__tab_style"> </ajaxCTK:TabContainer> Second per each tab include the following code corresponding to each ...

Rails - Basic Steps III

pValidations Validations are a type of ActiveRecord Validations are defined in our models Implement Validations Go to   root_app/app/models Open files  *.rb for each model Mandatory field validates_presence_of   :field Ex:   validates_presence_of    :title Classes The basic syntax is class MyClass        @global_variable                def my_method              @method_variable        end end Create an instance myInstance = MyClass.new Invoke a mehod mc.my_method class() method returns the type of the object In Ruby, last character of method define the behavior If ends with a question -> return a boolean value If ends with an exclamation -> change the state of the object Getter / Setter method def global_variable       return @global_variable end ...

Python create package

Create a root folder Create a sub-folder "example_pkg" that contains the funtionallity packaging_tutorial/ example_pkg/ __init__.py In the root folder create the following structure  packaging_tutorial/ example_pkg/ __init__.py tests/ setup.py LICENSE README.md in the setup.py contains the configuration of the packages your package is found by find_packages() import setuptools with open ( "README.md" , "r" ) as fh : long_description = fh . read () setuptools . setup ( name = "example-pkg-YOUR-USERNAME-HERE" , # Replace with your own username version = "0.0.1" , author = "Example Author" , author_email = "author@example.com" , description = "A small example package" , long_description = long_description , long_description_content_type = "text/markdown" , url = "https://github.com/pypa/sam...