在Windows 8 Metro应用程序中,我希望ListViewItems/Tiles在点击后打开链接。问题是点击时没有任何反应。与addEventListener我设法调用该项目,但代码无法打开链接。在Win8 Metro应用程序中使用javascript和html的tile上打开url地址应用程序
我将这样的Tiles存储在default.js文件中,我想访问“link”属性,它们都有一个。之后存在事件侦听和事件(的SelectItem):
var TileData = [
{ title: "Tile01", picture: "images/2.png", link: "http://www.gmail.com" },
{ title: "Tile02", picture: "images/1.png", link: "http://www.google.com" }
];
var dataList = new WinJS.Binding.List(TileData);
var publicMembers =
{
itemList: dataList
};
WinJS.Namespace.define("DataExample", publicMembers);
WinJS.Application.onmainwindowactivated = function (e) {
if (e.detail.kind === Windows.ApplicationModel.Activation.ActivationKind.launch) {
WinJS.UI.processAll().then(function() {
var TileList = document.getElementById('TileListView').winControl;
TileList.dataSource = TileData;
TileList.addEventListener('iteminvoked', SelectItem);
});
}
}
function SelectItem(e) {
var selectedItem = TileData[e.detail.itemIndex];
var selectedTileLink = document.getElementById('selectedTileLink');
selectedTileLink.src = selectedItem.link;
console.log('invoke ' + item.data.link);
Windows.System.Launcher.launchUriAsync(new Windows.Foundation.Uri(selectedTileLink));
}
var app = WinJS.Application;
app.onactivated = function (eventObject) {
if (eventObject.detail.kind === Windows.ApplicationModel.Activation.ActivationKind.launch) {
if (eventObject.detail.previousExecutionState !== Windows.ApplicationModel.Activation.ApplicationExecutionState.terminated) {
} else {
}
WinJS.UI.processAll(); //It reaches this point
}
};
app.oncheckpoint = function (eventObject) {
};
app.start();
为ListView模板是这里的选项,之后ListView控件本身:
<div id="TileItemTemplate" data-win-control="WinJS.Binding.Template">
<div style="width: 200px; height: 100px;">
<img src="#" style="width: 200px; height: 100px;"
data-win-bind="alt: title; src: picture" />
</div>
</div>
<div id="TileListView" data-win-control="WinJS.UI.ListView"
data-win-options="{
itemTemplate: select('#TileItemTemplate'),
itemDataSource : DataExample.itemList.dataSource,
layout:{type:WinJS.UI.GridLayout} }" >
</div>
所以我的问题是,该代码不会打开我在SelectItem函数中指定的链接。我将它存储在selectedTileLink中,但点击后没有任何反应。
有人可以帮我找到我的代码失败吗?
我真的很陌生地铁发展,我遇到了你写的事件处理程序的问题。我仍然无法访问链接。 是否有任何选项将“链接”存储为局部变量?例如:使用_onClick_我会运行一个JS函数,它将“链接”存储到本地变量中,并使用该参数打开Url。 – Lgn 2012-03-31 22:05:20
@Lgn我不太确定你在问什么。你能更详细地解释它吗?你是否将数据源绑定到列表视图?在调试器中,是否调用了itemInvoked事件处理程序?谢谢。 – 2012-03-31 23:40:42
我更新了我的问题,显示了我的代码,如果问题不多,请看看它。 – Lgn 2012-04-01 11:50:24