6

我正在尝试使用 Visual Studio 2012 在 Windows 8.1 上创建一个带有 angularJS 的 HTML5/JS/CSS3 应用程序。我目前坚持将参数发送到其他视图。

谷歌搜索时,我看到几个示例,<a href="#/page/{{:pageId}}">link</a>当我在 Windows 8 应用程序中执行此操作并单击链接时,我收到以下错误。

未安装任何应用程序来打开此类链接(不安全)

当我将{{:pageId}}代码放在 A 标记之间时,它会显示其 ID。

应用程序.js

var myApp = angular.module('myApp', ['ngRoute', 'ngResource']);

myApp.config(['$routeProvider', function($routeProvider) {
    $routeProvider.when("/", { templateUrl: "views/home.html" })
        .when("/page/:pageId", { templateUrl: "views/page.html" })
        .otherwise({ redirectTo: "/" });
}]);

有什么办法可以解决这个问题?

- 更新 -

我做了更多的调试。在浏览器中一切正常。在视觉工作室中,我发现了以下内容:

<a class="ng-binding" href="unsafe:ms-appx://3595d292-0235-47cd-8db7-cb3019f29114/www/index.html#/page/1" data-ng-href="#/page/1">Select</a>

看起来VS正在添加一些代码。在源代码中,我没有包含 href 项

我已经更改了链接,一切似乎都很好,并且仅加载了正确的变量 VS 不断在链接的前端添加“不安全:”。

4

1 回答 1

11

问题解决了!

似乎 ms 添加的 ms-appx 会导致问题。通过添加以下代码可以解决此问题。

AngularJS 1.2

app.config(['$compileProvider', function($compileProvider) {
  $compileProvider.aHrefSanitizationWhitelist(/^\s*(https?|file|ms-appx):/);
}]);

对于 1.1.x 和 1.0.x,使用 urlSanitizationWhitelist。

如果你使用PhoneGap,记得添加https以外的文件?否则,链接将不起作用。

于 2013-10-30T13:38:14.617 回答