控件(使用 JavaScript 的 HTML)

开发 前端
将新功能添加到 Windows 应用商店应用,例如自定义命令和和增强导航支持,以及 Windows 8.1 Preview 中的全新 HTML 和 JavaScript 控件。 对现有控件的更新可使这些控件更易于使用和添加更多功能,如拖放操作支持。 这些新控件和控件更新让创建功能齐全的应用变得前所未有的简单。

将新功能添加到 Windows 应用商店应用,例如自定义命令和和增强导航支持,以及 Windows 8.1 Preview 中的全新 HTML 和 JavaScript 控件。 对现有控件的更新可使这些控件更易于使用和添加更多功能,如拖放操作支持。 这些新控件和控件更新让创建功能齐全的应用变得***的简单。

新控件和控件更新

Windows 8.1 Preview 和适用于 JavaScript 2.0 Preview 的 Windows 库中引入了以下新控件和功能:

  • AppBarCommand
  • BackButton
  • Hub(中心)
  • ItemContainer
  • NavBar
  • Repeater
  • WebView

Windows 8.1 Preview 和适用于 JavaScript 2.0 Preview 的 Windows 库中包括这些现有控件的更新:

  • 对 ListView 的拖放操作支持
  • 对 ListView 中的项目重新排序
  • 新 ListView 布局:CellSpanningLayout
  • 其他 ListView 更新
  • 其他 Windows JavaScript 库更新

使用适用于 JavaScript 2.0 Preview 的 Windows 库

新的 Microsoft Visual Studio 2013 Preview 项目中会自动包含适用于 JavaScript 2.0 Preview 的 Windows 库。若要在使用 Windows 8 创建的项目中使用适用于 JavaScript 2.0 Preview 的 Windows 库,请将你的现有适用于 JavaScript 1 的 Windows 库引用替换为

  1. <!-- WinJS style sheets (include one) --> 
  2.     <link href="//Microsoft.WinJS.1.0/css/ui-dark.css" rel="stylesheet"> 
  3.     <link href="//Microsoft.WinJS.1.0/css/ui-light.css" rel="stylesheet"> 
  4.  
  5.     <!-- WinJS code --> 
  6.     <script src="//Microsoft.WinJS.1.0/js/base.js"></script> 
  7.     <script src="//Microsoft.WinJS.1.0/js/ui.js"></script> 

对适用于 JavaScript 2.0 Preview 的 Windows 库的引用。

  1. <!-- WinJS style sheets (include one) --> 
  2.     <link rel="stylesheet" href="//Microsoft.WinJS.2.0.Preview/css/ui-dark.css" /> 
  3.     <link rel="stylesheet" href="//Microsoft.WinJS.2.0.Preview/css/ui-light.css" /> 
  4.  
  5.     <!-- WinJS code --> 
  6.     <script src="//Microsoft.WinJS.2.0.Preview/js/base.js"></script> 
  7.     <script src="//Microsoft.WinJS.2.0.Preview/js/ui.js"></script> 

Visual Studio 2013 Preview 可以自动为你升级项目,你也可以手动完成以下更新:

  • 向项目中添加对适用于 JavaScript 的 Windows 8.1 库的引用。
  • 在你的应用清单中,将 OSMinVersionOSMaxVersionTested 值更新为 6.3.0:
  1. <Prerequisites> 
  2.     <OSMinVersion>6.3.0</OSMinVersion> 
  3.     <OSMaxVersionTested>6.3.0</OSMaxVersionTested> 
  4.   </Prerequisites> 

AppBarCommand

在 Windows 8.1 Preview 中,你可以使用一种名为“内容”的新型 AppBarCommand 在使用 JavaScript 的 Windows 应用商店应用中创建自定义应用栏命令。

此功能通过允许你在 commands 布局中放置自定义内容,从而简化了使用自定义内容创建应用栏的过程。你可以利用对使用自定义内容的应用栏命令的全面内置支持,包括键盘操作、命令定位,以及用于动态显示和隐藏命令的动画。

放入到 commands 布局中后,内容类型 AppBarCommand 支持很多与默认应用栏命令相同的功能。

  • 在默认应用栏命令和自定义 AppBarCommand 之间已启用键盘操作(Tab 键、箭头键、Home 键以及 End 键)。
  • 新的内容类型 AppBarCommand 能够正常使用应用栏可伸缩性。应用在被缩小之后会动态放弃文本标签。

BackButton

Windows 8.1 Preview 和适用于 JavaScript 2.0 Preview 的 Windows 库会以应用的控件形式向平台中添加更多导航支持。这些控件之一就是 BackButton

BackButton 为你提供一个向自己的应用中添加向后导航功能的简单方法。创建一个 BackButton 控件很简单。

  1. <button data-win-control="WinJS.UI.BackButton" ></button> 

BackButton 会自动检查导航堆栈,以确定用户是否可以向后导航。如果没有可向后导航的内容,此按钮会自动禁用。当用户单击此按钮或使用键盘快捷方式(如 Alt+ 向左键或 BrowserBack 键)时,它会自动调用 WinJS.Navigation.back 函数以向后导航。你无需编写任何代码。

Hub(中心)

为了帮助提供更一致的导航体验,Windows 8.1 Preview 和适用于 JavaScript 2.0 Preview 的 Windows 库添加了 Hub 控件。

很多 Windows 应用商店应用都使用中心导航模式,即一种分层的导航系统。此模式最适合具有大量内容或许多不同部分内容供用户浏览的应用。

中心设计的实质是将内容分为不同的部分和不同级别的详细信息。 中心页是用户进入应用的入口点。此处的内容显示在一个水平平移或垂直平移的平移视图中,这样用户一眼就能看见新增内容和可用功能。 中心由不同类别的内容构成,每个类别映射到应用的部分页中。每个部分都应该显示内容或功能。中心应该提供许多可以看到的变化,吸引用户,并将他们吸引到应用的各个部分。

中心页

 

有了 Windows 8.1 Preview,Hub 控件可使创建中心页更容易。若要开始快速创建带有 Hub 页的应用,请使用 Visual Studio 2013 Preview 中的“中心应用”模板。

创建中心

若要创建中心,你需要为中心包含的每个部分添加一个 Hub 控件和一个 HubSection 对象。每个 HubSection 都可以包含任何类型的内容,包括其他 Windows JavaScript 库控件。你可以使用 header 属性来指定节标题。部分头文件可为静态或交互文件。交互式头文件显示可隐藏的 V 形图标,并在用户与它们交互时提升事件。

以下示例定义了一个包含三个部分的 Hub

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4.     <meta charset="utf-8" /> 
  5.     <title>hubPage</title> 
  6.  
  7.     <!-- WinJS references --> 
  8.     <link href="//Microsoft.WinJS.2.0.Preview/css/ui-dark.css" rel="stylesheet" /> 
  9.     <script src="//Microsoft.WinJS.2.0.Preview/js/base.js"></script> 
  10.     <script src="//Microsoft.WinJS.2.0.Preview/js/ui.js"></script> 
  11.  
  12.     <link href="/css/default.css" rel="stylesheet" /> 
  13.     <link href="/pages/hub/hub.css" rel="stylesheet" /> 
  14.     <script src="/js/data.js"></script> 
  15.     <script src="/pages/hub/hub.js"></script> 
  16. </head> 
  17. <body> 
  18.     <div class="hubpage fragment"> 
  19.         <header aria-label="Header content" role="banner"> 
  20.             <button data-win-control="WinJS.UI.BackButton"></button> 
  21.             <h1 class="titlearea win-type-ellipsis"> 
  22.                 <span class="pagetitle">Hub example</span> 
  23.             </h1> 
  24.         </header> 
  25.  
  26.         <section class="hub" aria-label="Main content" role="main" data-win-control="WinJS.UI.Hub"> 
  27.             <!-- Customize the Hub control by modifying the HubSection controls here. --> 
  28.  
  29.  
  30.             <div class="section1" data-win-control="WinJS.UI.HubSection" data-win-options="{ isHeaderStatic: true }" data-win-res="{ winControl: {'header': 'Section1'} }"> 
  31.                 <img src="/images/gray.png" width="420" height="280" /> 
  32.                 <div class="subtext win-type-x-large secondary-text" data-win-res="{ textContent: 'Section1Subtext' }"></div> 
  33.                 <div class="win-type-medium" data-win-res="{ textContent: 'DescriptionText' }"></div> 
  34.                 <div class="win-type-small secondary-text"> 
  35.                     <span data-win-res="{ textContent: 'Section1Description' }"></span> 
  36.                     <span data-win-res="{ textContent: 'Section1Description' }"></span> 
  37.                     <span data-win-res="{ textContent: 'Section1Description' }"></span> 
  38.                 </div> 
  39.             </div> 
  40.  
  41.             <div class="section2" data-win-control="WinJS.UI.HubSection" data-win-res="{ winControl: {'header': 'Section2'} }" 
  42.                 data-win-options="{ onheaderinvoked: HubPage.section2HeaderNavigate }"> 
  43.                 <div class="itemTemplate" data-win-control="WinJS.Binding.Template"> 
  44.                     <img src="#" data-win-bind="src: backgroundImage; alt: title" /> 
  45.                     <div class="item-text"> 
  46.                         <div class="win-type-medium" data-win-bind="textContent: title"></div> 
  47.                         <div class="win-type-xx-small secondary-text" data-win-bind="textContent: subtitle"></div> 
  48.                         <div class="win-type-small secondary-text" data-win-bind="textContent: description"></div> 
  49.                     </div> 
  50.                 </div> 
  51.                 <div class="itemslist" data-win-control="WinJS.UI.ListView" data-win-options="{ 
  52.                         layout: {type: WinJS.UI.ListLayout2}, 
  53.                         selectionMode: 'none', 
  54.                         itemTemplate: select('.section2 .itemTemplate'),   
  55.                         itemDataSource: HubPage.section2DataSource, 
  56.                         oniteminvoked: HubPage.section2ItemNavigate 
  57.                     }"> 
  58.                 </div> 
  59.             </div> 
  60.  
  61.             <div class="section3" data-win-control="WinJS.UI.HubSection" data-win-options="{ isHeaderStatic: true }" data-win-res="{ winControl: {'header': 'Section3'} }"> 
  62.                 <div class="top-image-row"> 
  63.                     <img src="/images/gray.png" /> 
  64.                 </div> 
  65.                 <div class="sub-image-row"> 
  66.                     <img src="/images/gray.png" /> 
  67.                     <img src="/images/gray.png" /> 
  68.                     <img src="/images/gray.png" /> 
  69.                 </div> 
  70.                 <div class="win-type-medium" data-win-res="{ textContent: 'DescriptionText' }"></div> 
  71.                 <div class="win-type-small secondary-text"> 
  72.                     <span data-win-res="{ textContent: 'Section3Description' }"></span> 
  73.                     <span data-win-res="{ textContent: 'Section3Description' }"></span> 
  74.                 </div> 
  75.             </div> 
  76.  
  77.  
  78.         </section> 
  79.     </div> 
  80. </body> 
  81. </html> 

该代码创建此页面。

中心页

 

单击第二个标题时,应用会转到第二页。

部分页

 

以下代码执行导航。

  1. (function () { 
  2.     "use strict"
  3.  
  4.     var nav = WinJS.Navigation; 
  5.     var session = WinJS.Application.sessionState; 
  6.     var util = WinJS.Utilities; 
  7.  
  8.     // Get the groups used by the data-bound sections of the hub. 
  9.     var section2Group = Data.resolveGroupReference("group1"); 
  10.     var section5Group = Data.resolveGroupReference("group6"); 
  11.  
  12.     WinJS.UI.Pages.define("/pages/hub/hub.html", { 
  13.         // This function is called whenever a user navigates to this page. It 
  14.         // populates the page elements with the app's data. 
  15.         ready: function (element, options) { 
  16.             var hub = element.querySelector(".hub").winControl; 
  17.             hub.onloadingstatechanged = function (args) { 
  18.                 if (args.srcElement === hub.element && args.detail.loadingState === "complete") { 
  19.                     this._hubReady(hub); 
  20.                     hub.onloadingstatechanged = null
  21.                 } 
  22.             }.bind(this); 
  23.  
  24.             hub.onheaderinvoked = function (args) { 
  25.                 args.detail.section.onheaderinvoked(args); 
  26.             }; 
  27.  
  28.             // TODO: Initialize the page here. 
  29.         }, 
  30.  
  31.         unload: function () { 
  32.             // TODO: Respond to navigations away from this page. 
  33.             session.hubScroll = document.querySelector(".hub").winControl.scrollPosition; 
  34.         }, 
  35.  
  36.         updateLayout: function (element, viewState, lastViewState) { 
  37.             /// <param name="element" domElement="true" /> 
  38.  
  39.             // TODO: Respond to changes in viewState. 
  40.         }, 
  41.  
  42.         _hubReady: function (hub) { 
  43.             /// <param name="hub" type="WinJS.UI.Hub" /> 
  44.  
  45.             WinJS.Resources.processAll(); 
  46.             if (typeof session.hubScroll === "number") { 
  47.                 hub.scrollPosition = session.hubScroll; 
  48.             } 
  49.  
  50.             // TODO: Initialize the hub sections here. 
  51.         }, 
  52.     }); 
  53.  
  54.     function createHeaderNavigator(group) { 
  55.         return util.markSupportedForProcessing(function (args) { 
  56.             nav.navigate("/pages/section/section.html", { title: this.header, groupKey: group.key }); 
  57.         }); 
  58.     } 
  59.  
  60.     function createItemNavigator(group) { 
  61.         var items = Data.getItemsFromGroup(group); 
  62.         return util.markSupportedForProcessing(function (args) { 
  63.             var item = Data.getItemReference(items.getAt(args.detail.itemIndex)); 
  64.             nav.navigate("/pages/item/item.html", { item: item }); 
  65.         }); 
  66.     } 
  67.  
  68.     function getItemsDataSourceFromGroup(group) { 
  69.         return Data.getItemsFromGroup(group).dataSource; 
  70.     } 
  71.  
  72.     WinJS.Namespace.define("HubPage", { 
  73.         section2DataSource: getItemsDataSourceFromGroup(section2Group), 
  74.         section2HeaderNavigate: createHeaderNavigator(section2Group), 
  75.         section2ItemNavigate: createItemNavigator(section2Group), 
  76.         section5DataSource: getItemsDataSourceFromGroup(section5Group), 
  77.         section5ItemNavigate: createItemNavigator(section5Group) 
  78.     }); 
  79. })(); 

你甚至可使用 Hub 控件和 SemanticZoom 控件。有关此控制和更多的示例,请参阅 HTML 中心控件示例。

ItemContainer

新的 ItemContainer 控件可简化创建交互式元素的过程,这些元素提供了轻扫、拖放以及悬停功能。只需将你的内容放到 ItemContainer 中即可。ItemContainer 可以包含标准 HTML 元素,甚至其他 Windows JavaScript 库控件。

ItemContainer 很灵活,从而使其非常适合很多用途,如创建内容丰富的复选框组、导航按钮,以及购物车表示。

导航栏中的 ItemContainer 对象

当你希望显示项目,但又不需要使用全部 ListView 功能时,可以使用 ItemContainer 控件。

使用 ItemContainer

以下示例将创建两个 ItemContainer 对象,并将它们的 tapBehavior 属性设置为 toggleSelect 以便可以被选择。

  1. <div id="item1" 
  2.     data-win-control="WinJS.UI.ItemContainer" 
  3.     data-win-options="{tapBehavior: 'toggleSelect'}" 
  4.     style="width: 300px;"> 
  5.     <div style="margin: 10px; padding: 10px; background-color: lightgray"> 
  6.         <div class="win-type-x-large" 
  7.             style="margin-bottom: 5px;"> 
  8.             Banana 
  9.         </div> 
  10.         <img src="/images/60banana.png"> 
  11.         <div>Frozen yogurt</div> 
  12.     </div> 
  13. </div> 
  14. <div id="item2" 
  15.     data-win-control="WinJS.UI.ItemContainer" 
  16.     data-win-options="{tapBehavior: 'toggleSelect'}" 
  17.     style="width: 300px;"> 
  18.     <div style="margin: 10px; padding: 10px; background-color: lightgray"> 
  19.         <div class="win-type-x-large" 
  20.             style="margin-bottom: 5px;"> 
  21.             Strawberry 
  22.         </div> 
  23.         <img src="/images/60Strawberry.png"> 
  24.         <div>Ice cream</div> 
  25.     </div> 
  26. </div> 

两个 ItemContainer 对象

你还可以将一个 ItemContainer 与一个 Repeater 控件一起使用以从 List 生成项目:只需将 ItemContainer 放入你的 Template 控件中即可。

  1. <div id="itemTemplate" data-win-control="WinJS.Binding.Template"> 
  2.     <div   
  3.         data-win-control="WinJS.UI.ItemContainer"  
  4.         data-win-options="{tapBehavior: WinJS.UI.TapBehavior.toggleSelect}" 
  5.         style="width: 300px;"> 
  6.             <div  
  7.                  style=" margin: 10px; padding: 10px; background-color: lightgray"> 
  8.                 <div class="win-type-x-large"  
  9.                     style="margin-bottom: 5px;"  
  10.                     data-win-bind="textContent: title"></div> 
  11.                 <img src="#" data-win-bind="src: image"> 
  12.                 <div data-win-bind="textContent: desc"></div> 
  13.             </div> 
  14.     </div> 
  15. </div> 
  16.  
  17. <div data-win-control="WinJS.UI.Repeater"  
  18.     data-win-options="{data: ItemContainerExample.flavorList,  
  19.     template: select('#itemTemplate')}"> 
  20. </div> 

以下示例定义了数据源。

  1. (function () { 
  2.     "use strict"
  3.  
  4.     var basicList = new WinJS.Binding.List( 
  5.         [ 
  6.             { title: "Banana blast", desc: 'Frozen yogurt', image: '/images/60Banana.png'  }, 
  7.             { title: "Strawberry swirl", desc: 'Ice cream', image: '/images/60Strawberry.png' }, 
  8.             { title: "Magnificant mint", desc: 'Frozen yogurt', image: '/images/60Mint.png' }, 
  9.             { title: "Lemon lift", desc: 'Frozen yogurt', image: '/images/60Lemon.png' } 
  10.         ]); 
  11.  
  12.     WinJS.Namespace.define("ItemContainerExample"
  13.         { 
  14.             flavorList: basicList 
  15.  
  16.         }); 
  17. })(); 

Repeater 生成的 ItemContainer 对象

 

默认情况下可以选择项目。若要禁用选择,请将 ItemContainer 控件的 selectionDisabled 属性设置为 true

NavBar

[立即获取 HTML NavBar 控件示例。]

Windows 8.1 Preview 和适用于 JavaScript 2.0 Preview 的 Windows 库中引入了以下新控件,以帮助你提供一致且可预测的导航体验:WinJS.UI.NavBar 控件。

包含从数据源生成的导航项目的 NavBar

 

NavBar 类似于专用于导航命令的 AppBar。(实际上,NavBarAppBar 的子类。)它可以包含一系列简单的链接,也可以包含分类显示的多个级别的链接。你可以使用以下方法填充 NavBar:硬编码条目、以编程方式更新它,或者使用数据绑定。

NavBar 会在用户需要时显示在应用屏幕的页首。用户可以通过以下方式调用 NavBar:执行边缘轻扫、按 Windows 徽标键 + Z,或者右键单击。

NavBar 还支持垂直布局和拆分的导航项(具有子导航选项的导航项)。NavBar 是一个高度可自定义的对象:你可以使用级联样式表 (CSS) 设计 NavBar 及其内容的几乎所有方面的样式,还可以创建自定义导航项。

创建 NavBar

NavBar 包括三个组件:

  • NavBar 自身。
  • NavBarContainer 对象,它包含导航项(NavBarCommand 对象),并支持分页以及平移和滚动。在一个 NavBar 中可以包含一个或多个 NavBarContainer 对象。可以使用 NavBarContainer 对象来定义导航选项组。
  • 一个或多个 NavBarCommand 对象。 这些是用户单击可以导航的内容。

若要启用导航,你可以设置 NavBarCommand 对象的 location 属性。用户单击命令时,WinJS.Navigation.navigated 事件启动。 使用此事件导航到指定的位置。

也可以在 NavBar 上注册 oninvoked 事件,并使用你的事件处理程序执行导航操作。

以下示例显示了一个包含两个导航项的简单 NavBar

  1. <div id="NavBar" data-win-control="WinJS.UI.NavBar"> 
  2.     <div id="GlobalNav" data-win-control="WinJS.UI.NavBarContainer"> 
  3.             <div data-win-control="WinJS.UI.NavBarCommand" data-win-options="{ 
  4.                 label: 'Home', 
  5.                 icon: WinJS.UI.AppBarIcon.home, 
  6.                 location: '/html/home.html', 
  7.                 splitButton: false 
  8.                 }"> 
  9.             </div> 
  10.             <div data-win-control="WinJS.UI.NavBarCommand" data-win-options="{ 
  11.                 label: 'Your apps', 
  12.                 icon: WinJS.UI.AppBarIcon.favorite, 
  13.                 location: '/html/yourapps.html', 
  14.                 splitButton: false 
  15.                 }"> 
  16.             </div> 
  17.     </div> 
  18. </div> 

NavBar 如下所示。

NavBar

可创建包含子 NavBarCommand 对象的 NavBarCommand。要这样做,请将父 NavBarCommand 对象的 splitButton 属性设置为 true,然后使用 splittoggle 事件显示一个包含子 NavBarCommand 对象的 Flyout。此处是其***个部分的示例代码。

  1. <div id="useSplit" data-win-control="WinJS.UI.NavBar"> 
  2.     <div class="globalNav" data-win-control="WinJS.UI.NavBarContainer"> 
  3.         <div data-win-control="WinJS.UI.NavBarCommand"  
  4.             data-win-options="{ label: 'Home', icon: 'url(../images/homeIcon.png)' }"> 
  5.         </div> 
  6.         <div data-win-control="WinJS.UI.NavBarCommand"  
  7.             data-win-options="{ label: 'Favorite', icon: WinJS.UI.AppBarIcon.favorite, splitButton: 'true' }"> 
  8.         </div> 
  9.         <div data-win-control="WinJS.UI.NavBarCommand"  
  10.             data-win-options="{ label: 'Your account', icon: WinJS.UI.AppBarIcon.people }"> 
  11.         </div> 
  12.     </div> 
  13. </div> 
  14. <div id="contactFlyout" data-win-control="WinJS.UI.Flyout"  
  15.     data-win-options="{ placement: 'bottom' }"> 
  16.     <div id="contactNavBarContainer" data-win-control="WinJS.UI.NavBarContainer"}"> 
  17.         <div data-win-control="WinJS.UI.NavBarCommand"  
  18.             data-win-options="{ label: 'Family' }"> 
  19.         </div> 
  20.         <div data-win-control="WinJS.UI.NavBarCommand"  
  21.             data-win-options="{ label: 'Work' }"> 
  22.         </div> 
  23.         <div data-win-control="WinJS.UI.NavBarCommand"  
  24.             data-win-options="{ label: 'Friends' }"> 
  25.         </div> 
  26.         <div data-win-control="WinJS.UI.NavBarCommand"  
  27.             data-win-options="{ label: 'Blocked' }"> 
  28.         </div>   
  29.     </div> 
  30. </div> 

下一个示例显示了可初始化 HTML 页面,并添加 splittoggle 事件处理程序的代码,此事件处理程序可显示包含子 NavBarCommand 对象的 Flyout

  1. (function () { 
  2.     "use strict"
  3.     var navcontainer; 
  4.  
  5.     var page = WinJS.UI.Pages.define("/html/6-UseSplitButton.html", { 
  6.         ready: function (element, options) { 
  7.             document.body.querySelector('#useSplit').addEventListener('invoked'this.navbarInvoked.bind(this)); 
  8.             document.body.querySelector('#contactNavBarContainer').addEventListener('invoked'this.navbarInvoked.bind(this)); 
  9.  
  10.             var navBarContainerEl = document.body.querySelector('#useSplit .globalNav'); 
  11.             if (navBarContainerEl) { 
  12.                 this.setupNavBarContainer(); 
  13.             } else { 
  14.                 var navBarEl = document.getElementById('useSplit'); 
  15.                 navBarEl.addEventListener('childrenprocessed'this.setupNavBarContainer.bind(this)); 
  16.             } 
  17.         }, 
  18.  
  19.         navbarInvoked: function (ev) { 
  20.             var navbarCommand = ev.detail.navbarCommand; 
  21.             WinJS.log && WinJS.log(navbarCommand.label + " NavBarCommand invoked""sample""status"); 
  22.             document.querySelector('select').focus(); 
  23.         }, 
  24.  
  25.         setupNavBarContainer: function () { 
  26.             var navBarContainerEl = document.body.querySelector('#useSplit .globalNav'); 
  27.  
  28.             navBarContainerEl.addEventListener("splittoggle"function (e) { 
  29.                 var flyout = document.getElementById("contactFlyout").winControl; 
  30.                 var navbarCommand = e.detail.navbarCommand; 
  31.                 if (e.detail.opened) { 
  32.                     flyout.show(navbarCommand.element); 
  33.                     var subNavBarContainer = flyout.element.querySelector('.win-navbarcontainer'); 
  34.                     if (subNavBarContainer) { 
  35.                         // Switching the navbarcontainer from display none to display block requires  
  36.                         // forceLayout in case there was a pending measure. 
  37.                         subNavBarContainer.winControl.forceLayout(); 
  38.                         // Reset back to the first item. 
  39.                         subNavBarContainer.currentIndex = 0; 
  40.                     } 
  41.                     flyout.addEventListener('beforehide', go); 
  42.                 } else { 
  43.                     flyout.removeEventListener('beforehide', go); 
  44.                     flyout.hide(); 
  45.                 } 
  46.                 function go() { 
  47.                     flyout.removeEventListener('beforehide', go); 
  48.                     navbarCommand.splitOpened = false
  49.                 } 
  50.             }); 
  51.         } 
  52.     }); 
  53. })(); 

拆分按钮打开时的 NavBar 如下所示:

拆分 NavBarCommand

 

你可以将 NavBarContainer 绑定到数据源。为此,请创建一个包含描述导航命令的数据的 List,并将该列表用于设置 NavBarContainer 对象的 data 属性。以下示例定义供 NavBarContainer 使用的数据。

  1. (function () { 
  2.     "use strict"
  3.     var page = WinJS.UI.Pages.define("/html/2-UseData.html", { 
  4.         init: function (element, options) { 
  5.             var categoryNames = ["Picks for you""Popular""New Releases""Top Paid""Top Free"
  6.             "Games""Social""Entertainment""Photo""Music & Video"
  7.             "Sports""Books & Reference""News & Weather""Health & Fitness""Food & Dining"
  8.             "Lifestyle""Shopping""Travel""Finance""Productivity"
  9.             "Tools""Secuirty""Business""Education""Government"]; 
  10.  
  11.             var categoryItems = []; 
  12.             for (var i = 0; i < categoryNames.length; i++) { 
  13.                 categoryItems[i] = { 
  14.                     label: categoryNames[i] 
  15.                 }; 
  16.             } 
  17.  
  18.             Data.categoryList = new WinJS.Binding.List(categoryItems); 
  19.         }, 
  20.  
  21.         ready: function (element, options) { 
  22.             document.body.querySelector('#useTemplate').addEventListener('invoked'this.navbarInvoked.bind(this)); 
  23.         }, 
  24.  
  25.         navbarInvoked: function (ev) { 
  26.             var navbarCommand = ev.detail.navbarCommand; 
  27.             WinJS.log && WinJS.log(navbarCommand.label + " NavBarCommand invoked""sample""status"); 
  28.             document.querySelector('select').focus(); 
  29.         } 
  30.     }); 
  31. })(); 

下一个示例显示了可创建 NavBarNavBarContainer 对象的 HTML。

  1. div id="useTemplate" data-win-control="WinJS.UI.NavBar"> 
  2.     <div class="globalNav" data-win-control="WinJS.UI.NavBarContainer"> 
  3.         <div data-win-control="WinJS.UI.NavBarCommand"  
  4.              data-win-options="{ label: 'Home', icon: 'url(../images/homeIcon.png)' }"> 
  5.         </div> 
  6.         <div data-win-control="WinJS.UI.NavBarCommand"  
  7.              data-win-options="{ label: 'Favorite', icon: 'favorite' }"></div> 
  8.         <div data-win-control="WinJS.UI.NavBarCommand"  
  9.              data-win-options="{ label: 'Your account', icon: 'people' }"></div> 
  10.     </div> 
  11.     <div class="categoryNav"  
  12.         data-win-control="WinJS.UI.NavBarContainer"  
  13.         data-win-options="{ data: Data.categoryList, maxRows: 3 }"> 
  14.     </div> 
  15. </div> 

运行此代码时,它会创建此 NavBar

包含从数据源生成的导航项目的 NavBar

 

尽管此处没有显示,你仍可以使用 WinJS.Binding.Template 对象和数据源来生成导航栏项目。

Repeater

Repeater 是一个简单易用的 Windows JavaScript 库控件,该控件使用模板从一组数据中生成 HTML 标记。此模板可以包含几乎所有 HTML 标记和 Windows JavaScript 库控件。你甚至可以在 Repeater 控件中嵌套 Repeater 控件。

使用 Repeater 可以生成自定义列表和表格。以下是一个由 Repeater 创建的天气预报示例。

repeater 控件

 

Repeater 不是 ListView 控件的替代控件。它更灵活,但却不提供 ListView 所具备的一些高级功能,比如对如何加载数据项的控制。

使用 Repeater

RepeaterList 中生成其数据。以下示例将创建一个包含一些简单项的 List

  1. (function () { 
  2.     "use strict"; 
  3.  
  4.     var basicList2 = new WinJS.Binding.List( 
  5.         [ 
  6.             { title: "Item 1" }, 
  7.             { title: "Item 2" }, 
  8.             { title: "Item 3" }, 
  9.             { title: "Item 4" } 
  10.         ]); 
  11.  
  12.     WinJS.Namespace.define("RepeaterExample", 
  13.         { 
  14.             basicList: basicList2 
  15.  
  16.         }); 
  17. })(); 

要指定 Repeater 生成的标记,你可以定义一个 template。你可以创建一个标记模板或使用模板化功能。此示例可创建标记模板。 它通过数据绑定的方式将数据源的标题域绑定到 li 元素的文本内容。

  1. <div id="listTemplate" data-win-control="WinJS.Binding.Template"> 
  2.     <li data-win-bind="textContent: title"></li> 
  3. </div> 

下一示例将创建 Repeater 自身。

  1. <ul data-win-control="WinJS.UI.Repeater"  
  2.     data-win-options="{data: RepeaterExample.basicList,  
  3.     template: select('#listTemplate')}"> 
  4. </ul> 

当你运行此应用时,Repeater 会为数据列表中的每一项生成一个 li 元素。

Repeater 控件生成的列表

带有 SmartScreen 筛选器的 WebView

在 Windows 8 中,你可以使用 iframe 元素来托管基于 Web 的内容,但它无法提供很多内容隔离或导航功能。Windows 8.1 Preview 中引入了新的 WebView 控件,此控件可大大简化托管你的应用中基于 Web 内容的过程。

以下是一些 WebView 通过使用 iframe 显示基于 Web 的内容提供的改进:

  • 支持 HTML5

WebView 中托管的页面可访问大部分 HTML5 功能。(但是WebView 不能访问 IndexedDB、HTML5 应用缓存、地理位置 API 及 Clipboard API。)

  • 改进的导航支持

WebView 有其自己单独的历史记录堆栈,并提供多种向前导航,向后导航,以及重新加载当前页的方法。

  • 支持在帧中无法使用的站点

WebView 可以显示在 frameiframe 元素中无法使用的站点。

使用 WebView 加载内容

若要创建 WebView 控件,你需要创建一个 x-ms-webview 元素。

  1. <x-ms-webview id="webview"> 
  2. </x-ms-webview> 

你可以通过多种方式使用 WebView 加载内容:

  • 使用 WebView 控件的 src 属性、navigate 方法或 navigateWithHttpRequestMessage 方法导航到 URI。 本例使用 src 属性导航到 URI。
  1. <x-ms-webview id="webview" src="http://go.microsoft.com/fwlink/?LinkId=294155"  
  2.     style="width: 400px; height: 400px;"> 
  3. </x-ms-webview> 
  • 使用 navigateToString 方法来加载任意 HTML 字符串。
  1. var htmlString = "<!DOCTYPE html>" + 
  2.         "<html>" + 
  3.         "<head><title>Simple HTML page</title></head>" + 
  4.         "<body>" + 
  5.             "<h1>Hi!</h1>" + 
  6.             "<p>This is a simple HTML page.</p>" + 
  7.         "</body>" + 
  8.         "</html>"
  9. document.getElementById("webview").navigateToString( 
  10.     htmlString); 
  • 你可以使用 navigate 方法和 ms-appdata:// 协议来加载存储在应用的状态文件夹中的 HTML 内容。
  1. document.getElementById("webview").navigate( 
  2.     "ms-appdata:///local/NavigateToState/simple_example.html"); 

对于基于 HTML 的文件格式,它有时可以用于根据需要流式传输相对引用,如 WebView 控件本身无法呈现的加密 HTML 内容。使用 buildLocalStreamUrinavigateToLocalStreamUri 方法来显示媒体流中的内容。(你还必须实施一个使用 IUriToStreamResolver 接口的自定义 Windows 运行时对象。)

  1. var contentUri = document.getElementById("webview").buildLocalStreamUri(  
  2.     "NavigateToStream""simple_example.html");  
  3. var uriResolver = new SDK.WebViewSampleCS.StreamUriResolver();  
  4. document.getElementById("webview").navigateToLocalStreamUri(contentUri, uriResolver);  

对 ListView 的拖放操作支持

对于适用于 JavaScript 2.0 Preview 的 Windows 库,ListView 添加了对拖放操作的支持。这个新的支持与 HTML 5 拖放操作兼容。你可以在两个 ListView 控件之间,在一个 ItemContainer 和一个 ListView 之间,以及在任何 HTML 元素和 ListView 之间进行拖动。你可以通过在添加新项目后重新排序 ListView 控件的项目,让用户将项目拖放到 ListView 中的特定位置,也可以控制将拖放的项目插入到哪里。

从 ListView 拖动项目

若要启用将 ListView 中的项目拖动到 HTML 5 中的某个目标位置的操作,请完成以下操作:

  1. ListViewitemsDraggable 属性设置为 true
  2. 处理 ListView 控件的 itemdragstart 事件。在你的事件处理程序中,从事件对象的 detail 属性中获取一个 dataTransfer 对象。使用 dataTransfer 对象的 setData 方法来指定如何传输数据,以及传输哪些数据。
  3. 处理拖放目标的 dragover 事件。在你的事件处理程序中,使用 event 对象的 preventDefault 方法来告知系统你可接受拖放操作。否则,拖放目标将不接受拖放操作。
  4. 处理拖放目标的 drop 事件。在你的事件处理程序中,从事件对象的 detail 属性中获取一个 dataTransfer 对象。使用 dataTransfer 对象的 getData 属性检索传输的数据。使用此数据来更新拖放目标。 请谨慎操作,不要接受来自你的应用中本身可拖动项目的拖放内容,如选择的文本和 img 元素。

以下一组示例说明了如何启用从 ListView 中拖动项目的操作。***个示例定义了 HTML 标记。

  1. <div id="myDropTarget" class="DnDItem"> 
  2.     <div id="myTargetContents"> 
  3.         <p> 
  4.             HTML 5 Drop Target 
  5.         </p> 
  6.         <br /> 
  7.         <div id="myPlusSign" class="drop-ready"></div> 
  8.         <br /> 
  9.         <p> 
  10.             Drop Items Here 
  11.         </p> 
  12.     </div> 
  13. </div> 
  14.  
  15. <!-- Simple template for the ListView instantiation  --> 
  16. <div id="smallListIconTextTemplate" data-win-control="WinJS.Binding.Template" style="display: none"> 
  17.     <div class="smallListIconTextItem"> 
  18.         <img src="#" class="smallListIconTextItem-Image" data-win-bind="src: picture" draggable="false" /> 
  19.         <div class="smallListIconTextItem-Detail"> 
  20.             <h4 data-win-bind="innerText: title"></h4> 
  21.             <h6 data-win-bind="innerText: text"></h6> 
  22.         </div> 
  23.     </div> 
  24. </div> 
  25.  
  26. <!-- The declarative markup necessary for ListView instantiation --> 
  27. <!-- Call WinJS.UI.processAll() in your initialization code --> 
  28. <div id="listView" 
  29.     class="win-selectionstylefilled" 
  30.     data-win-control="WinJS.UI.ListView" 
  31.     data-win-options="{  
  32.         itemDataSource: myData.dataSource, 
  33.         selectionMode: 'none',  
  34.         itemTemplate: smallListIconTextTemplate, 
  35.         itemsDraggable: true, 
  36.         layout: { type: WinJS.UI.GridLayout }  
  37.     }"> 
  38. </div> 

下面是拖放操作的 CSS。

  1. .drop-ready #myPlusSign 
  2.     opacity: 1
  3.  
  4. #myPlusSign 
  5.      font-size:100px
  6.      font-weight:bolder
  7.      colorblue
  8.      opacity: 0

下一个示例显示了可启用拖放功能的代码。

  1. (function () { 
  2.     "use strict"
  3.     var page = WinJS.UI.Pages.define("/html/scenario2.html", { 
  4.         ready: function (element, options) { 
  5.  
  6.             listView.addEventListener("itemdragstart"function (eventObject) { 
  7.                 eventObject.detail.dataTransfer.setData("Text", JSON.stringify(eventObject.detail.dragInfo.getIndices())); 
  8.             }); 
  9.  
  10.             var dropTarget = element.querySelector("#myDropTarget"); 
  11.             dropTarget.addEventListener("dragover"function (eventObject) { 
  12.                 // Allow HTML5 drops. 
  13.                 eventObject.preventDefault(); 
  14.             }); 
  15.  
  16.             dropTarget.addEventListener("dragenter"function (eventObject) { 
  17.                 WinJS.Utilities.addClass(dropTarget, "drop-ready"); 
  18.             }); 
  19.  
  20.             dropTarget.addEventListener("dragleave"function (eventObject) { 
  21.                 WinJS.Utilities.removeClass(dropTarget, "drop-ready"); 
  22.             }); 
  23.  
  24.             dropTarget.addEventListener("drop"function (eventObject) { 
  25.                 // Get indicies -> keys of items that were trashed, and remove from datasource. 
  26.                 WinJS.Utilities.removeClass(dropTarget, "drop-ready"); 
  27.                 var indexSelected = JSON.parse(eventObject.dataTransfer.getData("Text")); 
  28.                 var listview = document.querySelector("#listView").winControl; 
  29.                 var ds = listview.itemDataSource; 
  30.  
  31.                 ds.itemFromIndex(indexSelected[0]).then(function (item) { 
  32.                     WinJS.log && WinJS.log("You dropped the item at index " + item.index + ", " 
  33.                     + item.data.title, "sample""status"); 
  34.                 }); 
  35.             }); 
  36.  
  37.         } 
  38.     }); 
  39.  
  40. })();

将项目拖放到 ListView 中

若要将元素拖放到 ListView 中的某个特定位置,请完成以下操作:

  1. 将 HTML 元素(拖放源)的 draggable 属性设置为 true
  2. 处理拖放目标的 dragstart 事件。 在你的事件处理程序中,从事件对象中获取一个 dataTransfer 对象。使用 dataTransfer 对象的 setData 方法来指定如何传输数据,以及传输哪些数据。
  3. 处理 ListView 控件的 itemdragenter 事件。在你的事件处理程序中,使用 event 对象的 preventDefault 方法来告知系统你可接受放置操作。否则,拖动操作可能会产生无法预料的结果。
  4. 处理 ListView 控件的 itemdragdrop 事件。 在你的事件处理程序中,从事件对象的 detail 属性中获取一个 dataTransfer 对象。使用 dataTransfer 对象的 getData 属性检索传输的数据。使用此数据来更新 ListView

以下一组示例说明了如何启用将项目拖放到 ListView 中的操作。***个示例定义了 HTML 标记。

  1. <div id="myDragSource" class="DnDItem"> 
  2.     <div id="mySourceContents"> 
  3.         <p> 
  4.             HTML 5 Drag Source 
  5.         </p> 
  6.         <br /> 
  7.         <br /> 
  8.         <br /> 
  9.         <div id="myDragContent" class="smallListIconTextItem" draggable="true"> 
  10.             <img id="myImg" src="/images/60Tree.png" class="smallListIconTextItem-Image" draggable="false" /> 
  11.             <div class="smallListIconTextItem-Detail"> 
  12.                 <h4 id="myItemTitle">Drag Me</h4> 
  13.             </div> 
  14.         </div> 
  15.     </div> 
  16. </div> 
  17.  
  18. <!-- Simple template for the ListView instantiation  --> 
  19. <div id="smallListIconTextTemplate" data-win-control="WinJS.Binding.Template" style="display: none"> 
  20.     <div class="smallListIconTextItem"> 
  21.         <img src="#" class="smallListIconTextItem-Image" data-win-bind="src: picture" draggable="false" /> 
  22.         <div class="smallListIconTextItem-Detail"> 
  23.             <h4 data-win-bind="innerText: title"></h4> 
  24.             <h6 data-win-bind="innerText: text"></h6> 
  25.         </div> 
  26.     </div> 
  27. </div> 
  28.  
  29. <!-- The declarative markup necessary for ListView instantiation --> 
  30. <!-- Call WinJS.UI.processAll() in your initialization code --> 
  31. <div id="listView" 
  32.     class="win-selectionstylefilled" 
  33.     data-win-control="WinJS.UI.ListView" 
  34.     data-win-options="{  
  35.         itemDataSource: myData.dataSource, 
  36.         selectionMode: 'none', 
  37.         itemTemplate: smallListIconTextTemplate, 
  38.         itemsReorderable: true, 
  39.         layout: { type: WinJS.UI.GridLayout }  
  40.     }"> 
  41. </div> 

下一个示例显示了可启用拖放功能的代码。

  1. (function () { 
  2.     "use strict"
  3.     var page = WinJS.UI.Pages.define("/html/scenario3.html", { 
  4.         ready: function (element, options) { 
  5.  
  6.             myDragContent.addEventListener("dragstart"function (eventObject) { 
  7.                 var dragData = { sourceElement: myDragContent.id, data: myItemTitle.innerText, imgSrc: myImg.src }; 
  8.                 eventObject.dataTransfer.setData("Text", JSON.stringify(dragData)); 
  9.             }); 
  10.  
  11.             listView.addEventListener("itemdragenter"function (eventObject) { 
  12.                 if (eventObject.detail.dataTransfer.types.contains("Text")) { 
  13.                     eventObject.preventDefault(); 
  14.                 } 
  15.             }); 
  16.  
  17.             listView.addEventListener("itemdragdrop"function (eventObject) { 
  18.                 var dragData = JSON.parse(eventObject.detail.dataTransfer.getData("Text")); 
  19.                 if (dragData && dragData.sourceElement === myDragContent.id) { 
  20.                     var newItemData = { title: dragData.data, text: ("id: " + dragData.sourceElement),  
  21.                                         picture: dragData.imgSrc }; 
  22.                     // insertAfterIndex tells us where in the list to add the new item. 
  23.                     // If we're inserting at the start, insertAfterIndex is -1.  
  24.                     // Adding 1 to insertAfterIndex gives us the nominal index in the array to insert the new item. 
  25.                     myData.splice(eventObject.detail.insertAfterIndex + 1, 0, newItemData); 
  26.                 } else { 
  27.                     // Throw error that illegal content was dropped. 
  28.                 } 
  29.             }); 
  30.         } 
  31.     }); 
  32. })(); 

 

对 ListView 中的项目重新排序

能够重新排序内容可帮助用户增强控制感。 新的 itemsReorderable 属性使用户能够轻松对 ListView 中的项目顺序进行更改。只需将 itemsReorderable 设置为 true 即可允许用户在 ListView 中拖放项目;无需其他代码。

Note  若要在一个分组的 ListView 中完全启用重新排序项目操作,你还必须对 itemdragdrop 事件做出响应,并将项目插入到正确位置。

Note  若要使重新排序操作顺利进行,你的数据源必须支持重新排序。

以下示例将创建一个支持项目重新排序的 ListView

  1. <style type="text/css"> 
  2.     .win-listview { 
  3.         margin: 20px; 
  4.         border: 2px solid gray; 
  5.         Width: 500px;  
  6.     } 
  7.  
  8.     .standardItem { 
  9.         width: 150px; 
  10.         height: 150px; 
  11.         background-color: #0aaddd; 
  12.         padding: 5px;  
  13.     } 
  14.  
  15. </style> 
  16.  
  17. <div id="template" data-win-control="WinJS.Binding.Template"> 
  18.     <div class="standardItem" data-win-bind="textContent: title" ></div> 
  19. </div> 
  20. <div 
  21.     id="reorderableListView" 
  22.     data-win-control="WinJS.UI.ListView" 
  23.     data-win-options="{ 
  24.     itemDataSource: ListViewExamples.dataList.dataSource,  
  25.     itemTemplate: select('#template'),  
  26.     layout: {type: WinJS.UI.GridLayout}, 
  27.     itemsReorderable: true  
  28.     }"> 
  29. </div> 

下一个示例定义了 ListView 使用的数据源。

  1. (function () { 
  2.     "use strict"; 
  3.  
  4.     var dataList = 
  5.         new WinJS.Binding.List( 
  6.              [{ title: "Item 1" }, 
  7.               { title: "Item 2" }, 
  8.               { title: "Item 3" }, 
  9.               { title: "Item 4" }]); 
  10.  
  11.     WinJS.Namespace.define("ListViewExamples", 
  12.         { 
  13.             dataList: dataList 
  14.         }) 
  15.  
  16. })(); 

代码运行时,用户可以通过拖动 ListView 项目来对项目进行重新排序。

ListView 重新排序

新 ListView 布局:CellSpanningLayout

使用适用于 JavaScript 1.0 的 Windows 库时,如果你希望 ListView 获取大小不同的项目,可以使用 GridLayout。对于适用于 JavaScript 2.0 Preview 的 Windows 库,我们添加了一个专门用于创建大小不同网格的新布局:CellSpanningLayout

以下示例为使用 CellSpanningLayoutListView 定义了数据源,以及 itemInfogroupInfo 方法。ListView 中的***个项目***为 510 像素,除此之外的所有其他项目大小均为 250 像素 X 250 像素。

  1. (function () { 
  2.     "use strict"
  3.  
  4.     var unorderedList = 
  5.         new WinJS.Binding.List( 
  6.              [{ title: "Item 1", cssClass: "tallItem" }, 
  7.               { title: "Item 2", cssClass: "standardItem" }, 
  8.               { title: "Item 3", cssClass: "standardItem" }, 
  9.               { title: "Item 4", cssClass: "standardItem" }]); 
  10.  
  11.     function myItemInfo(itemIndex) { 
  12.         var size = { width: 250, height: 250 }; 
  13.         if (itemIndex === 0) { 
  14.             size.height = 510; 
  15.         } 
  16.  
  17.         return size; 
  18.     }; 
  19.  
  20.     function myGroupInfo(groupInfo) { 
  21.         return { 
  22.             enableCellSpanning: true
  23.             cellWidth: 250, 
  24.             cellHeight: 250 
  25.         }; 
  26.     }; 
  27.  
  28.     WinJS.Utilities.markSupportedForProcessing(myItemInfo); 
  29.     WinJS.Utilities.markSupportedForProcessing(myGroupInfo); 
  30.  
  31.     WinJS.Namespace.define("ListViewExamples"
  32.         { 
  33.             unorderedList: unorderedList, 
  34.             myItemInfo: myItemInfo, 
  35.             myGroupInfo: myGroupInfo 
  36.         }) 
  37.  
  38.  
  39. })(); 

下一个示例显示了用于创建 ListViewWinJS.Binding.Template 的 HTML。

  1. <style type="text/css"
  2.     .win-listview { 
  3.         margin: 5px; 
  4.         border: 2px solid gray;  
  5.     } 
  6.  
  7.     .standardItem { 
  8.         width: 250px; 
  9.         height: 250px; 
  10.         background-color: #999999; 
  11.         padding: 5px;  
  12.     } 
  13.  
  14.     .tallItem { 
  15.         width: 250px; 
  16.         height: 510px; 
  17.         background-color: #0aaddd; 
  18.         padding: 5px;  
  19.     } 
  20. </style> 
  21.  
  22. <div id="template" data-win-control="WinJS.Binding.Template"
  23.     <div data-win-bind="className: cssClass; textContent: title" ></div> 
  24. </div> 
  25.  
  26. <div 
  27.     id="cellSpanningListView" 
  28.     data-win-control="WinJS.UI.ListView" 
  29.     data-win-options="{ 
  30.     itemDataSource: ListViewExamples.unorderedList.dataSource,  
  31.     itemTemplate: select('#template'),  
  32.     layout: {type: WinJS.UI.CellSpanningLayout,  
  33.     itemInfo: ListViewExamples.myItemInfo,  
  34.     groupInfo: ListViewExamples.myGroupInfo} 
  35.     }"> 
  36. </div> 

ListView 如下所示。

一个使用 CellSpanningLayout 的 ListView

其他 ListView 更新

Windows 8.1 Preview 包括对 ListView 控件的更多改进。

改进了头文件的可访问性

分组的 ListView 中的标题现在支持键盘导航,以及键盘和鼠标插入。你无需进行任何代码更改即可获取这些新功能。

(有关创建组的详细信息,请参阅如何对 ListView 中的项进行分组。)

Note  如果你通过在适用于 JavaScript 1.0 的 Windows 库中包含链接或按钮而将头文件设置为不可调用,则当你切换到适用于 JavaScript 2.0 Preview 的 Windows 库时,用户将无法使用键盘调用此头文件。 若要解决此问题,请处理 ongroupheaderinvoked 事件,并使用此事件来执行头文件操作,而不是使用按钮或链接。

对布局接口的更新

ListView 现在有一组新的布局接口,使你能够更轻松地创建自己的自定义布局:ILayout2 和 ISiteLayout2。实现这些接口时,你可以将标准 CSS 布局用作你的实现的一部分。

ListLayout 和 GridLayout 更新

我们已更新 ListLayoutGridLayout 以提高它们的整体性能,尤其是平移性能。你无需进行任何代码更改即可利用这些改进。

其他 Windows JavaScript 库更新

绑定和 WinJS.Binding.Template 更新

适用于 JavaScript 2.0 Preview 的 Windows 库使用一个更加高效的新系统来处理 Template 对象,可显著提高性能。这个新系统可以使数据绑定和控件实例化过程更为流畅,并且可以并行完成,而无需再像使用适用于 JavaScript 1.0 的 Windows 库那样需要串行完成。如果你的代码依靠传统串行处理行为,我们建议更改你的代码以利用更快的模板处理。但如果你无法更改代码,可使用 disableOptimizedProcessing 属性恢复原行为。

释放 API

释放模型是一种新模式,它允许元素和控件在其生存期结束时释放其资源,以防止内存泄露。 元素或控件可以选择实现此模式。有资源要释放的适用于 JavaScript 2.0 Preview 的 Windows 库控件现在可以实现此 API。

若要利用此释放模型,请在不再需要此控件时调用该控件的 dispose 方法,比如,当你导航离开某个页面,或关闭应用时。

原文链接:http://msdn.microsoft.com/zh-cn/library/windows/apps/bg182879.aspx#AppBarCommand

责任编辑:陈四芳 来源: microsoft.com
相关推荐

2009-08-03 17:31:26

.NET验证控件

2012-04-27 14:43:42

HTML5

2009-07-30 12:42:19

html控件和web控

2009-08-04 11:29:14

HTML代码ASP.NET控件

2011-11-07 09:56:17

HTML 5

2012-07-16 10:04:45

JavaScript

2009-07-24 09:57:25

ASP.NET HTM

2012-12-27 16:46:19

Android开发AutoComplet

2024-09-14 15:07:03

2009-08-03 15:43:22

asp.net控件

2009-07-27 13:20:19

HTML Map控件ASP.NET

2011-04-19 17:06:24

bada控件bada

2012-06-28 10:21:37

JavaScript

2011-03-09 15:16:06

SilverlightHTML

2022-06-23 09:00:00

JavaScriptHTML应用程序

2009-07-21 15:50:47

ASP.NET控件JavaScript

2023-10-07 08:00:00

JavaScriptHTMX

2009-07-24 15:35:00

ASP.NET Gri

2009-08-26 17:28:48

C# DateTime

2013-09-16 10:19:08

htmlcssJavaScript
点赞
收藏

51CTO技术栈公众号