⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 multipage.htc

📁 浏览器端看到树型目录结构,用户可以完整地看到像windows资源管理器一样的效果
💻 HTC
字号:
<!----------------------------------------------------------------------
//  Copyright (c) 2000-2003 Microsoft Corporation.  All Rights Reserved.
//---------------------------------------------------------------------->

<public:component tagName="MultiPage" lightweight="true">

<public:property name="selectedIndex" get="GetPageIndex" put="SetPageIndex" persist="true" value="0" id="propSelectedIndex" />
<public:property name="numPages" get="NumPages" id="propNumPages" />

<public:method name="createPageAt" internalname="f_CreatePageAt" />

<public:event name="onselectedindexchange" id="evtPageChange" />

<public:attach event="oncontentready" onevent="Init()" />

<public:defaults
    tabStop="false"
    contentEditable="false"
    canHaveHTML="true"
    viewInheritStyle="true"
    viewMasterTab="false"
    viewLinkContent="false"
    style="display:block;visibility:hidden;overflow:auto"
/>

<script language="JScript">

var _PageIndex = null;
var _bInitProcess;  // To not fire property change events during init

function f_CreatePageAt(index)
{
    var numPages = NumPages();
    if ((index < 0) || (index > numPages))
        index = numPages;

    var page = element.document.createElement("PageView");
    page.style.display = "none";
    page.attachEvent("onpropertychange", OnPropertyChange);

    if (index == numPages)
    {
        element.appendChild(page);
    }
    else
    {
        element.children[index].insertAdjacentElement("beforeBegin", page);
    }

    if (index <= _PageIndex)
    {
        _bInitProcess = true;
        SetPageIndex(_PageIndex + 1);
        _bInitProcess = false;
    }

    if (!_bInitProcess)
    {
        propNumPages.fireChange();
        if (_PageIndex < 0)
            SetPageIndex(0);
    }

    return page;
}

function OnPropertyChange()
{
    if (event.propertyName.toLowerCase() == "activate")
    {
        var oNode = event.srcElement;
        var bActivate = oNode.getAttribute("activate");
        if ((bActivate != null) && (bActivate))
        {
            SetPageIndex(ConvertPageToIndex(oNode));
        }
    }
}

function Init()
{
    _bInitProcess = true;

    ProcessContent();

    var initIndex;
    if (numPages == 0)
        initIndex = -1;
    else if ((_PageIndex == null) || (_PageIndex == "") || (_PageIndex < 0) || (_PageIndex >= numPages) || (GetPage(_PageIndex) == null))
        initIndex = 0;
    else
        initIndex = _PageIndex;

    _PageIndex = -1;    // Needed so that SetPageIndex will actually set the index
    SetPageIndex(initIndex);

    defaults.style.visibility = "inherit";

    _bInitProcess = false;
}

function ProcessContent()
{
    for (var nIndex = 0; nIndex < element.childNodes.length; nIndex++)
    {
        var node = element.childNodes[nIndex];
        if ((node.tagName != null) && (node.tagName.toLowerCase() == "pageview"))
        {
            node.style.display = "none";
            node.attachEvent("onpropertychange", OnPropertyChange);
        }
        else
        {
            node.removeNode(true);
            nIndex--;
        }
    }
}

function NumPages()
{
    return element.childNodes.length;
}

function GetPage(nIndex)
{
    if ((nIndex == null) || (nIndex < 0) || 
        (nIndex >= element.childNodes.length))
        return null;

    return element.childNodes[nIndex];
}

function ConvertPageToIndex(page)
{
    for (var nIndex = 0; nIndex < element.childNodes.length; nIndex++)
    {
        var node = element.childNodes[nIndex];
        if (node.uniqueID == page.uniqueID)
            return nIndex;
    }

    return -1;
}

function GetPageIndex()
{
    return _PageIndex;
}

function SetPageIndex(value)
{
    if (_PageIndex == value)
        return;

    var page = GetPage(value);
    var prevPage = GetPage(_PageIndex);

    if ((_PageIndex == null) || (page != null))
        _PageIndex = value;

    if (page == null)
        return;
 
    if (prevPage != null)
    {
        prevPage.style.display = "none";
    }

    page.style.display = "block";

    if (!_bInitProcess)
    {
        var oEvent = CreatePageEvent(value, page);
        evtPageChange.fire(oEvent);
    }

    if (!_bInitProcess)
        propSelectedIndex.fireChange();
}

function CreatePageEvent(index, page)
{
    oEvent = createEventObject();
    oEvent.selectedIndex = index;
    oEvent.page = page;

    return oEvent;
}

</script>

</public:component>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -