<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                * 不要在控制器里操作 DOM。通過指令完成。 * 通過控制器完成的功能命名控制器 (如:購物卡,主頁,控制板),并以字符串`Ctrl`結尾。控制器采用駝峰命名法 (`HomePageCtrl`,?`ShoppingCartCtrl`,?`AdminPanelCtrl`, etc.). * 控制器不應該在全局中定義 (盡管 AngularJS 允許,但污染全局空間是個糟糕的實踐)。 * 使用一下語法定義控制器: ~~~ function MyCtrl(dependency1, dependency2, ..., dependencyn) { // ... } module.controller('MyCtrl', MyCtrl); ~~~ 使用這種定義方式可以最大的避免問題。你可以使用工具自動生成數組定義,如:[ng-annotate](https://github.com/olov/ng-annotate)?(and grunt task?[grunt-ng-annotate](https://github.com/mzgol/grunt-ng-annotate)). * 使用控制器依賴的原名。這將提高代碼的可讀性: ~~~ function MyCtrl(s) { // ... } module.controller('MyCtrl', ['$scope', MyCtrl]); ~~~ 下面的代碼更易理解 ~~~ function MyCtrl($scope) { // ... } module.controller('MyCtrl', ['$scope', MyCtrl]); ~~~ 對于包含大量代碼的需要上下滾動的文件尤其適用。這可能使你忘記某一變量是對應哪一個依賴。 * 盡可能的精簡控制器。將通用函數抽象為獨立的服務。 * 通過方法引用進行跨控制器通訊 (通常是子控制器與父控制器通訊) 或者?`$emit`,?`$broadcast`?及?`$on`?方法。發送或廣播的消息應該限定在最小的作用域。 * 制定一個通過?`$emit`,?`$broadcast`?發送的消息列表并且仔細的管理以防命名沖突和bug。 * 在需要格式化數據時將格式化邏輯封裝成?[過濾器](https://github.com/mgechev/angularjs-style-guide/blob/master/README-zh-cn.md#filters)?并將其聲明為依賴: ~~~ function myFormat() { return function () { // ... }; } module.filter('myFormat', myFormat); function MyCtrl($scope, myFormatFilter) { // ... } module.controller('MyCtrl', MyCtrl); ~~~ * 當內嵌的控制器 使用 "內嵌 scoping" (?`controllerAs`?語法): **app.js** ~~~ module.config(function ($routeProvider) { $routeProvider .when('/route', { templateUrl: 'partials/template.html', controller: 'HomeCtrl', controllerAs: 'home' }); }); ~~~ **HomeCtrl** ~~~ function HomeCtrl() { this.bindingValue = 42; } ~~~ **template.html** ~~~ <div ng-bind="home.bindingValue"></div> ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看