javascript - AngularJS页面切换问题
阿神
阿神 2017-04-11 12:49:53
0
4
604

刚开始学习,想用angular+ionic写一个页面切换的效果。
点击page1中的一个图片,页面切换为page2。
因为页面太多不想写那么多html,所以使用ng-show。
代码如下:


html:

<body ng-controller="binder">

    <!-- page1 -->
    <p ng-show="controller.page('home')">
        <p class="content">
            <button class="item item-image" ng-click="controller.switch('myDevice')">
                <img src="img/choose_mine.png">
            </button>
        </p>
    </p>

    <!-- page2 -->
    <p ng-show="controller.page('myDevice')">
        <ion-content style="background-color: rgb(235,237,240)">
            <a class="item item-image" href="#" style="margin: 5px 5px 7px 5px">
                <img src="img/choose_D1.png">
            </a>
        </ion-content>
    </p>

    <script src="bower_components/ionic/release/js/ionic.bundle.js"></script>
    <script src="bower_components/angular-route/angular-route.js"></script>
    <script src="bower_components/angular-animate/angular-animate.js"></script>
    <script src="app.js"></script>
</body>

js:

var bindDevice = angular.module('bind',['ionic']);

bindDevice.controller('binder',function () {
    var self = this;
    self.indexPage = 'home';

    self.page = function (page) {
        return page == self.indexPage;
    };

    self.switch = function (index) {
        self.indexPage = index;
    };

})

不知道哪里出了问题,运行效果是页面闪现一下然后就消失了。
本人小白,希望大神们能够帮忙看看,感激不尽。

阿神
阿神

闭关修行中......

répondre à tous(4)
迷茫

页面切换还是建议使用 ui-router

Ty80

个人理解这应该和分页一样吧 所以你试试配置路由

洪涛

既然是var self = this, 首先ng-controller最好写为ng-controller="binder as self".
其次,controller里的scope变量应该写为 self.xxx, 所以你的ng-show应该写成 ng-show="self.page('xxx')"

大家讲道理

angular1 现在已经满足不了 项目需求了,建议学习angular2

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal