javascript - 重新加载并检查用户是否使用 angularjs 连接到 phonegap

标签 javascript angularjs cordova onsen-ui

我正在使用 phonegap 创建一个应用程序。我成功地检查了用户是否连接到互联网。但是如果用户没有连接。我想放置一个按钮,以便用户可以单击重新加载并重新加载页面。这是我的代码的样子:

<ons-template id="directory.html">
    <ons-navigator var="app.navi" >
    <div ng-if="online"> <!-- Check If user is online or not -->
    <ons-page ng-controller="directoryControl">
      <ons-toolbar>
        <div class="left">
          <ons-toolbar-button ng-click="menu.toggle()">
            <ons-icon icon="ion-navicon" size="28px" fixed-width="false"></ons-icon>
          </ons-toolbar-button>
        </div>
        <div class="center">Directory List</div>
      </ons-toolbar>
     <p>Yes you are Connected!</p>
    </ons-page>
    </div>

    <div ng-if="!online">
      <ons-page>
      <ons-toolbar>
        <div class="left">
          <ons-toolbar-button ng-click="menu.toggle()">
            <ons-icon icon="ion-navicon" size="28px" fixed-width="false"></ons-icon>
          </ons-toolbar-button>
        </div>
        <div class="center">Directory List</div>
      </ons-toolbar>

        <p>Oops! You are not online..!<br/><ons-button ng-click="app.navi.pushPage('directory.html')">Reload</ons-button></p>
      </ons-page>
    </div>
  </ons-navigator>
</ons-template>

我希望用户点击 <ons-button ng-click="app.navi.pushPage('directory.html')">Reload</ons-button>这个按钮然后可以重新连接到离开的页面。

这里我使用的是单页模板结构。

如果你想看一下 Controller ,那么作为引用,我正在使用下面的 Controller ,而我根本没有使用 ng-view/route。

    module.controller('directoryControl', function($scope, $http, $rootScope, ajaxCall) {
    ons.ready(function() {

var dataURL = "get_category_index";
var valuePickup = "categories"
ajaxCall.GetIndex($scope, dataURL, valuePickup);

$scope.setCurrentCategory = function(categoryName){
     $scope.CurrentCategory = categoryName;
     $rootScope.CurrentCategory=$scope.CurrentCategory;
            }
        });
    });

这里必须要用route吗?还是有其他方法可以做到这一点?

我只想使用重新加载页面并保持在同一页面上而不重新启动进程。

最佳答案

您可以使用Network cordova plugin

https://github.com/apache/cordova-plugin-network-information

安装

cordova plugin add https://github.com/apache/cordova-plugin-network-information

示例代码

function checkConnection() {
    var networkState = navigator.connection.type;

    var states = {};
    states[Connection.UNKNOWN]  = 'Unknown connection';
    states[Connection.ETHERNET] = 'Ethernet connection';
    states[Connection.WIFI]     = 'WiFi connection';
    states[Connection.CELL_2G]  = 'Cell 2G connection';
    states[Connection.CELL_3G]  = 'Cell 3G connection';
    states[Connection.CELL_4G]  = 'Cell 4G connection';
    states[Connection.CELL]     = 'Cell generic connection';
    states[Connection.NONE]     = 'No network connection';

    alert('Connection type: ' + states[networkState]);
}

checkConnection();

关于javascript - 重新加载并检查用户是否使用 angularjs 连接到 phonegap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29929664/

相关文章:

javascript - jQuery 在表单内的 div 中选择 div

javascript - 使用 Ajax 和 jQuery 无法在 div 部分显示 Json 数据

javascript - Angular 图表上的重叠图例 Piechart

javascript - 单击按钮时的 jQuery 动画表单

javascript - 使用 CodeMirror 的 Bootstrap 选项卡

java - AngularJS 加载页面,其中包含来自 Controller 的不相关数据(2 个 GETS 还是只有 1 个?)

angularjs - 等待页面加载超时

javascript - 在 Cordova 获取设备高度

javascript - 如何将从数据库中取出的数据设置为div内容?

android - ionic cordova build android找不到模块 '../pages/Wallet/'