关于 ng-template 的引用问题


//a.html
<div controller="modalController">
    <a ng-click="openModal()"> open modal</a>
</div>

//b.html
<script type="text/ng-template" id="modal.tmpl.html">
    <div class="wrap-content reference">
        This is a modal.
    </div>
</script>

//c.js 支持es6语法
import './b.html';

var app = angular.module('app', ['ui.bootstrap']);
app.controller('modalController', ['$scope', '$uibModal', function($scope, $uibModal) {
    var modalInstance = $uibModal.open({
        templateUrl: 'modal.tmpl.html',
        size: 'md'
    });
}]);

上述写法不能打开模态窗,但是把b.html中的代码放入a.html中,就能够打开模态窗,请问这是为什么呢?

我在c.js文件中已经导入了b.html了呀。。

阅读 4.2k
1 个回答

这是因为angular不知道你的b.html,你可以看下$templatecache这个东西

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题