- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我注意到与这个主题相关的大多数问题都是关于 jQuery $(document).ready
函数的替代方法,它是 angular.element($ document).ready
但是我想要一个可测试/最佳实践的替代方案。
我目前正在注入(inject) Bing map ,它需要在执行我的 Controller 中的代码之前加载。
目前我将 Controller 代码包装在准备好的文档中:
angular.element($document).ready(function() {
self.map = new Microsoft.Maps.Map(document.getElementById('map'), {
credentials: $scope.credentials,
enableClickableLogo: false,
enableSearchLogo: false,
showDashboard: false,
disableBirdseye: true,
allowInfoboxOverflow: true,
liteMode: true,
minZoom: 2
});
$scope.$watch('zoom', function (zoom) {
self.map.setView({animate: true, zoom: zoom});
});
if ($scope.onMapReady) {
$scope.onMapReady({ map: self.map });
}
});
哪个有效,但我无法测试它,所以我认为这是不正确的用法。我尝试在 $scope.loaded = true;
的指令中设置一个变量,因为我读到如果命中指令链接函数,则必须加载 DOM。然后我尝试用以下内容替换准备就绪的文档:
$scope.$watch('loaded', function () {
self.map = new Microsoft.Maps.Map(document.getElementById('map'), {
credentials: $scope.credentials,
enableClickableLogo: false,
enableSearchLogo: false,
showDashboard: false,
disableBirdseye: true,
allowInfoboxOverflow: true,
liteMode: true,
minZoom: 2
});
if ($scope.onMapReady) {
$scope.onMapReady({ map: self.map });
}
});
$scope.$watch('zoom', function (zoom) {
self.map.setView({animate: true, zoom: zoom});
});
“已加载” watch 按预期工作,但自然会在加载时缩放,那是在设置 map 之前。我觉得我可以将准备好的文档更改为 $timeout
函数,但这似乎是一种解决方法而不是正确的解决方案,是否有替代 angular.element($document ).ready
以相同的方式工作但允许我成功测试它的内容?
最佳答案
通常 Angular 应用程序已经在文档 ready
上启动了.这是使用 ng-app
自动引导的默认行为, 和手动引导 angular.bootstrap
应该在 ready
上执行
该问题特定于当前案例(Microsoft 的 Bing Maps API)。考虑到 ready
is suggested by Microsoft ,开发人员可以自己找到更好的选择。
<script src="https://www.bing.com/api/maps/mapcontrol"></script>
是同步加载的,但它会触发一些依赖项来加载,这些依赖项在初始文档 ready
时尚未加载。被触发。实际上,它需要 ready
在另一个里面 ready
为了完成初始化,这正是原始代码和微软示例所展示的,看起来不太好。
为了避免竞争条件,应用程序 Bootstrap 可以推迟到加载所有先决条件的那一刻,即 window load
event instead of document ready
.它可能会提供相当大的延迟,但它可以保证加载应用程序所依赖的脚本,而不管它们的传输是如何执行的:
angular.element(window).on('load', () => {
angular.bootstrap(document.body, ['app']
});
API 提供的控制初始化过程的替代方法是global callback function :
<script src="https://www.bing.com/api/maps/mapcontrol?callback=globalCallbackName"></script>
回调可以与服务打包在一起,而不是依赖于 <script>
:
angular.module('bingMaps', [])
.factory('bingMapsLoader', ($q, $window, $document, $timeout) => {
var script = document.createElement('script');
script.src = 'https://www.bing.com/api/maps/mapcontrol?callback=bingMapsCallback';
script.async = true;
$document.find('body').append(script);
return $q((resolve, reject) => {
$window.bingMapsCallback = resolve;
$timeout(reject, 30000);
});
});
bingMapsLoader
可以链接 promise 以保证 API 已初始化、放入路由器解析器等。
此外, Controller 构造函数在编译指令之前执行。无论是否使用第三方 API,将所有特定于 DOM 的代码移动到 Angular 1.4 及更低版本中的前/后链接函数和 Controller 都是正确的 $onInit
或 $postLink
在 Angular 1.5 或更高版本中 Hook :
app.controller('FooController', function (bingMapsLoader) {
this.$postLink = () => {
bingMapsLoader.then(() => this.mapsInit());
};
this.mapsInit = () => {
Microsoft.Maps.Map(...);
};
...
关于javascript - 替代 angular.element(document).ready,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44674270/
根据 jQueryDoc在术语中,.ready() 被称为位于 jQuery.prototype 中的查询选择方法。对于前 $(document).ready() 作为jQueryDoc说:$ 命名空
我见过一些代码,他们只是这样做: $().ready(function() { ... }); 这比执行文档选择器要短,但它是同一件事吗? 最佳答案 略有变化: $(document).rea
各个处理程序的回调函数何时执行? 最佳答案 在主要过程中 当您的应用完成初始化并准备打开浏览器窗口时,将触发app上的“就绪”事件。由于在此之前您无法打开窗口,因此可以使用回调函数来创建Browser
最近发现了head.js图书馆和男孩,我对此感到满意,尽管我仍然对一件事感到有点困惑。 来自 headjs.com: The “DOM ready” event such as $(document)
我在我的代码库中发现代码在另一个 $(document).ready(function() { ... 例如 $(document).ready(function() { // 20
我已经养成了从ready函数开始jquery编码的习惯 $(function(){...}); 并将所有从ready调用的函数放入ready中。 然后我意识到,放入就绪函数中的一些函数可能不需要在那里
在浏览旧代码库时,我发现了以前的软件开发人员正在使用的地方 $(function(a) {}(A || (A = {}))); 即使页面尚未准备好,它仍在执行。在我删除传递的全局变量后它开始工作。代码
我已经看到了两种方式,但哪种更好或者并不重要。 我觉得包装每个语句可能会更干净,但只是想知道如果您有 50 个语句,每个语句都有自己的 document.ready 事件处理程序,是否会有更多回调?
这个问题已经有答案了: Four variations of jQuery ready() -- what's the difference? (4 个回答) 已关闭 4 年前。 我正在编写一些我没有
我们最近遇到了一个错误,jquery document.ready 似乎在 DOM 加载之前触发。事实证明,在调用的第一个项目之后有一些错误的代码 $.ready(function(){}); 这条语
什么应该在 jQuery.ready() 中,什么应该在 jQuery.ready() 之外? 从性能角度来看,我在某处读到,将所有代码包装在 jQuery.ready() 中并不是一种有效的方法。
我实现了一个带有选项列表(工作类别)的页面,单击该页面时应显示数据(工作描述)。我正在使用 BBQ 来处理后台堆栈。 一切正常,除了在用户首次导航到页面时设置初始选择。我的代码被调用到 addClas
解决方案 我有两个 users.js和 users.coffee在我的 Assets 管道中。显然 users.coffee正在阻止 users.js从被加载。确保删除它! 我正在尝试实现 this
我正在研究一个指令,但我不想玩 $document或 $window , 只有 element本身。 之前我有: angular.element($document).ready(function()
我想在移动设备方向改变时使用 $(window).resize 来调用一些函数,我在 $(document).ready 中编写了所有代码,这在我使用 Android 设备时有效,但在使用 iPhon
我有一个使用数据库的 Ionic 应用程序。我想用一个文件的内容填充这个数据库。 这部分我开始工作了。我想创建一个 DB.ready() 事件,很像 $ionicPlatform.ready() 或
我有一个名为“loadTimeTrackersGrid()”的函数,它加载一个弹性网格。设置如下所示: $(document).ready(function () { var edi
我有一个定义数量为 replicas 的部署.如果我的 Pod 准备好/未准备好处理新连接,我使用就绪探针进行通信 - 我的 Pod 在 ready 之间切换/not ready他们一生中的状态。 我
有什么区别: $(document).ready(initialize); 和 $(document).on('ready', initialize); 对我来说,它们似乎以相同的方式工作。 最佳答案
我看到很多项目都在使用 $(document).on('ready', function(e){ //jquery stuff }) 而不是: $( document ).ready(functio
我是一名优秀的程序员,十分优秀!