当我使用“幻灯片”过渡转换到person.html页面时,出现以下错误:“无法从ons-page元素获取PageView。”

从“幻灯片”更改为“淡入淡出”时,我没有收到错误。

<ons-navigator title="Navigator" var="myNavigator">
    <ons-sliding-menu main-page="index.html" menu-page="menu-timeline.html" max-slide-distance="260px" type="push" var="menu">
    </ons-sliding-menu>
    <ons-template id="index.html">
        <ons-page>
            <ons-toolbar>
                <div class="left">
                    <ons-toolbar-button>
                        <ons-icon icon="ion-home" fixed-width="false" style="font-size: 26px; vertical-align: -4px"></ons-icon>
                        People App
                    </ons-toolbar-button>
                </div>
                <div class="center">People</div>
                <div class="right">
                    <ons-toolbar-button>
                        <ons-icon icon="ion-search" onclick="myNavigator.pushPage('search-global.html', { animation : 'fade' } )"></ons-icon>
                    </ons-toolbar-button>
                    <ons-toolbar-button ng-click="menu.toggleMenu()">
                        <ons-icon icon="ion-more"></ons-icon>
                    </ons-toolbar-button>
                </div>
            </ons-toolbar>
            <!-- changing 'slide' to 'fade' below removes the error -->
            <ons-list class="timeline" modifier="inset">
                <ons-list-item class="timeline-li" modifier="tappable" ng-repeat="i in [1,2,3]" ng-click="myNavigator.pushPage('person.html', { animation : 'slide' } )">
                    <ons-row>
                        <ons-col width="50px">
                            <img ng-src="https://placeholdit.imgix.net/~text?txtsize=8&txt=50%C3%9750&w=50&h=50" class="timeline-image">
                        </ons-col>
                        <ons-col>
                            <div class="timline-from">
                                <span class="timeline-name">My Awesome Friend</span>
                            </div>
                        </ons-col>
                    </ons-row>
                </ons-list-item>
            </ons-list>

        </ons-page>
    </ons-template>

    <ons-template id="menu-timeline.html">
        <ons-page modifier="menu-page">
            <ons-toolbar modifier="transparent">
                <div class="right">
                    <ons-toolbar-button class="menu-closeMenu" ng-click="menu.closeMenu()">
                        </ons-icon>Close
                    </ons-toolbar-button>
                </div>
            </ons-toolbar>
            <ons-list class="menu-list">
                <ons-list-item class="menu-item" ng-click="menu.closeMenu()">
                    <ons-icon icon="fa-plus"></ons-icon>
                    New Person
                </ons-list-item>
            </ons-list>
        </ons-page>
    </ons-template>
    <ons-template id="person.html">
        <ons-page>
            <ons-toolbar>
                <div class="left">
                    <ons-toolbar-button onclick="myNavigator.popPage();">
                        <ons-icon icon="ion-arrow-left-a" fixed-width="false" style="font-size: 20px;vertical-align:-3px;margin-right:3px;"></ons-icon>
                        <ons-icon icon="ion-home" fixed-width="false" style="font-size: 26px; vertical-align: -4px"></ons-icon>
                    </ons-toolbar-button>
                </div>
                <div class="center">Person Name. </div>
                <div class="right">

                    <ons-toolbar-button ng-click="menu.toggleMenu()">
                        <ons-icon icon="ion-android-more-vertical"></ons-icon>
                    </ons-toolbar-button>
                </div>
            </ons-toolbar>
            <ons-list>
                <ons-list-item>
                    Hello. I am Person Name.
                </ons-list-item>
                <ons-list-item>
                    If this page appeared using 'slide' then an error resulted.
                </ons-list-item>
                <ons-list-item>
                    If it appeared using 'fade' then it should still function fine.
                </ons-list-item>
            </ons-list>
        </ons-page>
    </ons-template>
    <ons-template id="search-global.html">
        <ons-page>
            <ons-toolbar>
                <div class="left">
                    <ons-toolbar-button onclick="myNavigator.popPage();">
                        <ons-icon icon="ion-arrow-left-a" fixed-width="false" style="font-size: 20px;vertical-align:-3px;margin-right:3px;"></ons-icon>
                        <ons-icon icon="ion-home" fixed-width="false" style="font-size: 26px; vertical-align: -4px"></ons-icon>
                    </ons-toolbar-button>
                </div>
                <div class="center">Search People</div>
            </ons-toolbar>
            <ons-list>
                <ons-list-item>
                    <input type="text" placeholder="Enter search text" class="text-input text-input--transparent" style="margin-top:8px; width: 100%;">
                </ons-list-item>
                <ons-list-item style="padding-bottom:8px;padding-top:5px;">
                    <ons-button modifier="large" onclick="">
                        Search
                    </ons-button>
                </ons-list-item>
            </ons-list>
        </ons-page>
    </ons-template>
</ons-navigator>


我更喜欢使用幻灯片过渡,因为我认为它使导航看起来更加线性。有谁知道我该如何解决这个错误?

这是CodePen:http://codepen.io/blarney2000/pen/qZoVzW

最佳答案

基本上,它只是无法找到初始页面。如果仅将滑动菜单包装在页面内,就可以了。 Demo

<ons-navigator title="Navigator" var="myNavigator">
  <ons-page>
    <ons-sliding-menu main-page="index.html" menu-page="menu-timeline.html" max-slide-distance="260px" type="push" var="menu">
    </ons-sliding-menu>
  </ons-page>
</ons-navigator>


为什么仅在幻灯片上出错,这是一个谜,但是Onsen 1的开发已经完成,因此,如果是Bug,则不太可能在版本1中得到修复。因此,解决方案只是放置页面和所有内容将工作。另外,如果需要的话,可以将导航器放在滑动菜单中。然后,您可以拥有ons-sliding-menu > ons-navigator > ons-page

10-07 17:56