簡體   English   中英

angularJS和Bootstrap:錯誤:[$ injector:unpr]

[英]angularJS and Bootstrap: Error: [$injector:unpr]

我對angularJS還是Web開發領域的新手,所以這是我的問題:我試圖創建一個書店網頁,用戶在其中使用模態輸入數據,問題是何時嘗試為模態創建控制器,對於“取消”按鈕,它會給我您在標題中看到的錯誤,即:

“ angular.js:14961錯誤:[$ injector:unpr]”。

我進行了很多搜索,但是找不到任何解決方案。 我可以打開模態。

注意:我不是英語母語人士,我在西班牙語頁面中嘗試過,沒有運氣。 我希望你能幫助我。

編碼:

我的index.html

<!DOCTYPE>
<html >
    <head>
        <meta charset="UTF-8">
        <title>Book Store</title>
        <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" integrity="sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7" crossorigin="anonymous">
    </head>
    <body ng-app="app" ng-controller="myController as ctrl">
        <h1>Welcome to book store</h1>
        <table >
            <tr>
                <th>Titulo</th>
                <th>Autor</th>
                <th>Editorial</th>
                <th>Edicion</th>
            </tr>
            <tr ng-repeat="x in listaLibros">
                <td>{{x.name}}</td>
                <td>{{x.autor}}</td>
                <td>{{x.editorial}}</td>
                <td>{{x.edition}}</td>
            </tr>
        </table>
        <div class="form-group">
            <button type="button" uib-tooltip="Click this button to do something amazing." class="btn btn-primary">Hover to show Tooltip</button>
        </div>


        <button type="button" class="btn btn-default" ng-click="control.open()">Open me!</button>

    </body>


    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.10/angular.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/1.3.3/ui-bootstrap.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/1.3.3/ui-bootstrap-tpls.min.js"></script>
    <script src= "app.js" ></script>
</html>

agregarLibro.html

<html>
  <body></body>
<div class="modal-content">

    <div class="modal-header" ng-app="app">
        <h4 class="modal-title">Agregar libro</h4>


        <div class="modal-body">
        <h6>Titulo</h6>
        <input type="text" ng-model="listaLibros.name">
        <h6>Autor</h6>
        <input type="text" ng-model="listaLibros.autor">
        <h6>Editorial</h6>
        <input type="text" ng-model="listaLibros.editorial">
        <h6>Edicion</h6>
        <input type="text" ng-model="listaLibros.edition">
    </div>


    <button type="button" class="btn btn-danger" data-dismiss="modal" ng-click="$ctrl.cancel()">X</button>
    <button type="button" class="btn btn-success">Agregar libro</button>

</div>
</body>
</html>

和app.js

var app = angular.module("app", ['ui.bootstrap']);




app.controller("myController",function($scope, $http, $uibModal,){
    var control = this;

    $http.get("dataLibros.json")
    .then(function(response){
        $scope.listaLibros = response.data;
    });


    control.open = function(){
        var modalInstance = $uibModal.open({
            templateUrl: "agregarLibro.html",
            controller: 'ModalInstanceCtrl',
            controllerAs: '$ctrl',

        })
    }
});

app.controller('ModalInstanceCtrl', function ($uibModalInstance, items) {
    var $ctrl = this;

    $ctrl.cancel = function () {
      $uibModalInstance.dismiss('cancel');
    };
});

幾乎沒有錯誤

(i)您需要將腳本嵌入到body標簽中,而不是oustside body標簽oustside

  <div class="form-group">
    <button type="button" uib-tooltip="Click this button to do something amazing." class="btn btn-primary">Hover to show Tooltip</button>
  </div>
  <button type="button" class="btn btn-default" ng-click="control.open()">Open me!</button>
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.10/angular.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/1.3.3/ui-bootstrap.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/1.3.3/ui-bootstrap-tpls.min.js"></script>
  <script src="app.js"></script>
</body>

(ii)您應該使用`ng-click =“ ctrl.open()”

  <button type="button" class="btn btn-default" ng-click="ctrl.open()">Open me!</button>

(iIi)從模態中刪除ng-app,一個應用中只能有一個ng-app

<div class="modal-header" ng-app="app">

DEMO

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM