Use underscore inside Angular controllers

前端 未结 6 1132
轮回少年
轮回少年 2020-11-30 16:16

How do I use underscore library inside angularjs controllers?

On this post: AngularJS limitTo by last 2 records somebody suggested to assign an _ variable to the ro

相关标签:
6条回答
  • 2020-11-30 16:45

    I use this:

    var myapp = angular.module('myApp', [])
      // allow DI for use in controllers, unit tests
      .constant('_', window._)
      // use in views, ng-repeat="x in _.range(3)"
      .run(function ($rootScope) {
         $rootScope._ = window._;
      });
    

    See https://github.com/angular/angular.js/wiki/Understanding-Dependency-Injection about halfway for some more info on run.

    0 讨论(0)
  • 2020-11-30 16:48

    you can use this module -> https://github.com/jiahut/ng.lodash

    this is for lodash so does underscore

    0 讨论(0)
  • 2020-11-30 16:57

    If you don't mind using lodash try out https://github.com/rockabox/ng-lodash it wraps lodash completely so it is the only dependency and you don't need to load any other script files such as lodash.

    Lodash is completely off of the window scope and no "hoping" that it's been loaded prior to your module.

    0 讨论(0)
  • 2020-11-30 17:03

    When you include Underscore, it attaches itself to the window object, and so is available globally.

    So you can use it from Angular code as-is.

    You can also wrap it up in a service or a factory, if you'd like it to be injected:

    var underscore = angular.module('underscore', []);
    underscore.factory('_', ['$window', function($window) {
      return $window._; // assumes underscore has already been loaded on the page
    }]);
    

    And then you can ask for the _ in your app's module:

    // Declare it as a dependency of your module
    var app = angular.module('app', ['underscore']);
    
    // And then inject it where you need it
    app.controller('Ctrl', function($scope, _) {
      // do stuff
    });
    
    0 讨论(0)
  • 2020-11-30 17:05

    You can also take a look at this module for angular

    https://github.com/floydsoft/angular-underscore

    0 讨论(0)
  • 2020-11-30 17:06

    I have implemented @satchmorun's suggestion here: https://github.com/andresesfm/angular-underscore-module

    To use it:

    1. Make sure you have included underscore.js in your project

      <script src="bower_components/underscore/underscore.js">
      
    2. Get it:

      bower install angular-underscore-module
      
    3. Add angular-underscore-module.js to your main file (index.html)

      <script src="bower_components/angular-underscore-module/angular-underscore-module.js"></script>
      
    4. Add the module as a dependency in your App definition

      var myapp = angular.module('MyApp', ['underscore'])
      
    5. To use, add as an injected dependency to your Controller/Service and it is ready to use

      angular.module('MyApp').controller('MyCtrl', function ($scope, _) {
      ...
      //Use underscore
      _.each(...);
      ...
      
    0 讨论(0)
提交回复
热议问题