Ionic 1 使用 iframe - 如果没有互联网则隐藏并在互联网可用时重新加载
Ionic 1 working with iframe - Hide if there is no internet and reload when internet available
我是 ionic 的新手,我坚持让 iframe 在没有互联网连接时隐藏,并在 ionic 1 上重新连接互联网时重新加载。
我在 ionic 论坛和 Whosebug 上看到了答案,比如使用 navigator.online
if (navigator.onLine) {
alert('There is internet connection available');
}
else{
alert('There is no internet connection available');
}
但问题是我不知道如何将它连接到 iframe。
www/js/app.js
ionic// Ionic Starter App
// angular.module is a global place for creating, registering and retrieving
Angular modules
// 'starter' is the name of this angular module example (also set in a <body>
attribute in index.html)
// the 2nd parameter is an array of 'requires'
// 'starter.controllers' is found in controllers.js
angular.module('starter', ['ionic', 'starter.controllers'])
//if use wakanda platform
angular.module('starter', ['ionic', 'starter.controllers','wakanda' ])
.run(function($ionicPlatform,$rootScope,$location,$ionicScrollDelegate,
$ionicPopup) {
// if(window.Connection) {
// if(navigator.connection.type == Connection.NONE) {
// alert('There is no internet connection available');
// }else{
// alert(navigator.connection.type);
// }
// }else{
// alert('Cannot find Window n.Connection');
// }
if (navigator.onLine) {
alert('There is internet connection available');
}
else{
alert('There is no internet connection available');
}
/*************** forget password ****************/
$rootScope.forget_password=function (){
$ionicPopup.show({
template: 'Enter your email address below.<label class="item item-input"
style=" height: 34px; margin-top: 10px;"><input type="email" /></label>',
title: 'Forget Password',
subTitle: ' ',
scope: $rootScope,
buttons: [
{text: 'Send',
type: 'button-clear dark-blue'},
{ text: 'Cancel' ,
type: 'button-clear main-bg-color'},]
});
};
/*************** increment-decrement function ****************/
$rootScope.valueKids=1;
$rootScope.valueAdults=1;
$rootScope.valueBabies=1;
$rootScope.increment_val= function(type) {
if (type=='Kids'&&$rootScope.valueKids >= 0) $rootScope.valueKids++;
if (type=='Adults'&&$rootScope.valueAdults >= 0) $rootScope.valueAdults++;
if (type=='Babies'&&$rootScope.valueBabies >= 0) $rootScope.valueBabies++;
};
$rootScope.decrement_val = function(type) {
//if ($rootScope.value > 0) $rootScope.value--;
if (type=='Kids'&&$rootScope.valueKids > 0) $rootScope.valueKids--;
if (type=='Adults'&&$rootScope.valueAdults > 0) $rootScope.valueAdults--;
if (type=='Babies'&&$rootScope.valueBabies > 0) $rootScope.valueBabies--;
};
$rootScope.confirmMsg=function(index){
$rootScope.show_msg=index
}
$rootScope.scrollTop = function() {
$ionicScrollDelegate.scrollTop();
};
/*************** group function ****************/
$rootScope.groups = [
{id: 1, items: [{ subName: 'SubBubbles1'}]},
{id: 2, items: [{ subName: 'SubBubbles1'}]},
{id: 3, items: [{ subName: 'SubBubbles1'}]},
{id: 4, items: [{ subName: 'SubBubbles1'}]},
{id: 5, items: [{ subName: 'SubBubbles1'}]},
{id: 6, items: [{ subName: 'SubBubbles1'}]},
{id: 7, items: [{ subName: 'SubBubbles1'}]}
];
/*
* if given group is the selected group, deselect it
* else, select the given group
*/
$rootScope.toggleGroup = function(group) {
if ($rootScope.isGroupShown(group)) {
$rootScope.shownGroup = null;
} else {
$rootScope.shownGroup = group;
}
};
$rootScope.isGroupShown = function(group) {
return $rootScope.shownGroup === group;
};
/*************** location function ****************/
$rootScope.goto=function(url){
$location.path(url)
}
/*************** active function ****************/
$rootScope.activeIcon=1
$rootScope.activeTab=function(index){
$rootScope.activeIcon=index
}
/*************** repeat array ****************/
$rootScope.menu =[{id:"1",img:"img/1.png",title:"Book
Flight",name:"right",link:"#/app/search"},
{id:"2",img:"img/2.png",title:"Manage
Booking",link:"#/app/reservations"},
{id:"3",img:"img/3.png",title:"Destinations",link:"#/app/offer"},
{id:"4",img:"img/4.png",title:"Plan
Trip",link:"#/app/register"},
{id:"5",img:"img/5.png",title:"Contact
Us",link:"#/app/contact"},
{id:"6",img:"img/6.png",title:"About
Us",link:"#/app/about"}]
$rootScope.det =[{id:"1"},
{id:"2"}]
$rootScope.data =[{id:"1"},
{id:"2"},{id:"3"},{id:"4"},{id:"5"}]
$ionicPlatform.ready(function() {
// Hide the accessory bar by default (remove this to show the accessory bar above the keyboard
// for form inputs)
if (window.cordova && window.cordova.plugins.Keyboard) {
cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
}
if (window.StatusBar) {
// org.apache.cordova.statusbar required
StatusBar.styleDefault();
}
});
})
.config(function($stateProvider, $urlRouterProvider,$ionicConfigProvider) {
$ionicConfigProvider.navBar.alignTitle('center');
$ionicConfigProvider.backButton.text('').previousTitleText('');
$stateProvider
.state('home', {
url: "/home",
templateUrl: "templates/home.html"
})
.state('app', {
url: "/app",
abstract: true,
templateUrl: "templates/menu.html",
controller: 'AppCtrl'
})
.state('app.search', {
url: "/search",
views: {
'menuContent': {
templateUrl: "templates/search.html"
}
}
})
.state('app.payment', {
url: "/payment",
views: {
'menuContent': {
templateUrl: "templates/payment.html"
}
}
})
.state('app.contact', {
url: "/contact",
views: {
'menuContent': {
templateUrl: "templates/contact.html"
}
}
})
.state('app.reservations', {
url: "/reservations",
views: {
'menuContent': {
templateUrl: "templates/reservations.html"
}
}
})
.state('app.details', {
url: "/details",
views: {
'menuContent': {
templateUrl: "templates/details.html"
}
}
})
.state('app.data', {
url: "/data",
views: {
'menuContent': {
templateUrl: "templates/data.html"
}
}
})
.state('app.offer', {
url: "/offer",
views: {
'menuContent': {
templateUrl: "templates/offer.html"
}
}
})
.state('app.register', {
url: "/register",
views: {
'menuContent': {
templateUrl: "templates/register.html"
}
}
})
.state('app.about', {
url: "/about",
views: {
'menuContent': {
templateUrl: "templates/about.html"
}
}
});
// if none of the above states are matched, use this as the fallback
$urlRouterProvider.otherwise('/home');
});
search.html
<ion-content class="search_content padding" scroll="false" style="background-
color: darkred">
<div class="tab-content animated fadeInUp">
<ion-scroll direction="y" style="height: 100%">
<iframe name="chatFrame" id="iframe"
class="iframe" style="BORDER-BOTTOM: medium none; BORDER-LEFT: medium none;
BORDER-TOP: medium none; BORDER-RIGHT: medium none;width:100%;min-
height:290px" src="https://example.com" align="top" scrolling="auto">
</iframe>
</ion-scroll>
</div>
您可以在控制器中维护一个标志,如下所示。
if (navigator.onLine) {
$scope.isNetworkAvailable = true;
}
else{
$scope.isNetworkAvailable = false;
}
在 HTML 中使用 isNetworkAvailable 标志,如下所示
<iframe ng-if="isNetworkAvailable " name="chatFrame" id="iframe"
class="iframe" style="BORDER-BOTTOM: medium none; BORDER-LEFT: medium none;
BORDER-TOP: medium none; BORDER-RIGHT: medium none;width:100%;min-
height:290px" src="https://example.com" align="top" scrolling="auto">
</iframe>
我是 ionic 的新手,我坚持让 iframe 在没有互联网连接时隐藏,并在 ionic 1 上重新连接互联网时重新加载。
我在 ionic 论坛和 Whosebug 上看到了答案,比如使用 navigator.online
if (navigator.onLine) {
alert('There is internet connection available');
}
else{
alert('There is no internet connection available');
}
但问题是我不知道如何将它连接到 iframe。
www/js/app.js
ionic// Ionic Starter App
// angular.module is a global place for creating, registering and retrieving
Angular modules
// 'starter' is the name of this angular module example (also set in a <body>
attribute in index.html)
// the 2nd parameter is an array of 'requires'
// 'starter.controllers' is found in controllers.js
angular.module('starter', ['ionic', 'starter.controllers'])
//if use wakanda platform
angular.module('starter', ['ionic', 'starter.controllers','wakanda' ])
.run(function($ionicPlatform,$rootScope,$location,$ionicScrollDelegate,
$ionicPopup) {
// if(window.Connection) {
// if(navigator.connection.type == Connection.NONE) {
// alert('There is no internet connection available');
// }else{
// alert(navigator.connection.type);
// }
// }else{
// alert('Cannot find Window n.Connection');
// }
if (navigator.onLine) {
alert('There is internet connection available');
}
else{
alert('There is no internet connection available');
}
/*************** forget password ****************/
$rootScope.forget_password=function (){
$ionicPopup.show({
template: 'Enter your email address below.<label class="item item-input"
style=" height: 34px; margin-top: 10px;"><input type="email" /></label>',
title: 'Forget Password',
subTitle: ' ',
scope: $rootScope,
buttons: [
{text: 'Send',
type: 'button-clear dark-blue'},
{ text: 'Cancel' ,
type: 'button-clear main-bg-color'},]
});
};
/*************** increment-decrement function ****************/
$rootScope.valueKids=1;
$rootScope.valueAdults=1;
$rootScope.valueBabies=1;
$rootScope.increment_val= function(type) {
if (type=='Kids'&&$rootScope.valueKids >= 0) $rootScope.valueKids++;
if (type=='Adults'&&$rootScope.valueAdults >= 0) $rootScope.valueAdults++;
if (type=='Babies'&&$rootScope.valueBabies >= 0) $rootScope.valueBabies++;
};
$rootScope.decrement_val = function(type) {
//if ($rootScope.value > 0) $rootScope.value--;
if (type=='Kids'&&$rootScope.valueKids > 0) $rootScope.valueKids--;
if (type=='Adults'&&$rootScope.valueAdults > 0) $rootScope.valueAdults--;
if (type=='Babies'&&$rootScope.valueBabies > 0) $rootScope.valueBabies--;
};
$rootScope.confirmMsg=function(index){
$rootScope.show_msg=index
}
$rootScope.scrollTop = function() {
$ionicScrollDelegate.scrollTop();
};
/*************** group function ****************/
$rootScope.groups = [
{id: 1, items: [{ subName: 'SubBubbles1'}]},
{id: 2, items: [{ subName: 'SubBubbles1'}]},
{id: 3, items: [{ subName: 'SubBubbles1'}]},
{id: 4, items: [{ subName: 'SubBubbles1'}]},
{id: 5, items: [{ subName: 'SubBubbles1'}]},
{id: 6, items: [{ subName: 'SubBubbles1'}]},
{id: 7, items: [{ subName: 'SubBubbles1'}]}
];
/*
* if given group is the selected group, deselect it
* else, select the given group
*/
$rootScope.toggleGroup = function(group) {
if ($rootScope.isGroupShown(group)) {
$rootScope.shownGroup = null;
} else {
$rootScope.shownGroup = group;
}
};
$rootScope.isGroupShown = function(group) {
return $rootScope.shownGroup === group;
};
/*************** location function ****************/
$rootScope.goto=function(url){
$location.path(url)
}
/*************** active function ****************/
$rootScope.activeIcon=1
$rootScope.activeTab=function(index){
$rootScope.activeIcon=index
}
/*************** repeat array ****************/
$rootScope.menu =[{id:"1",img:"img/1.png",title:"Book
Flight",name:"right",link:"#/app/search"},
{id:"2",img:"img/2.png",title:"Manage
Booking",link:"#/app/reservations"},
{id:"3",img:"img/3.png",title:"Destinations",link:"#/app/offer"},
{id:"4",img:"img/4.png",title:"Plan
Trip",link:"#/app/register"},
{id:"5",img:"img/5.png",title:"Contact
Us",link:"#/app/contact"},
{id:"6",img:"img/6.png",title:"About
Us",link:"#/app/about"}]
$rootScope.det =[{id:"1"},
{id:"2"}]
$rootScope.data =[{id:"1"},
{id:"2"},{id:"3"},{id:"4"},{id:"5"}]
$ionicPlatform.ready(function() {
// Hide the accessory bar by default (remove this to show the accessory bar above the keyboard
// for form inputs)
if (window.cordova && window.cordova.plugins.Keyboard) {
cordova.plugins.Keyboard.hideKeyboardAccessoryBar(true);
}
if (window.StatusBar) {
// org.apache.cordova.statusbar required
StatusBar.styleDefault();
}
});
})
.config(function($stateProvider, $urlRouterProvider,$ionicConfigProvider) {
$ionicConfigProvider.navBar.alignTitle('center');
$ionicConfigProvider.backButton.text('').previousTitleText('');
$stateProvider
.state('home', {
url: "/home",
templateUrl: "templates/home.html"
})
.state('app', {
url: "/app",
abstract: true,
templateUrl: "templates/menu.html",
controller: 'AppCtrl'
})
.state('app.search', {
url: "/search",
views: {
'menuContent': {
templateUrl: "templates/search.html"
}
}
})
.state('app.payment', {
url: "/payment",
views: {
'menuContent': {
templateUrl: "templates/payment.html"
}
}
})
.state('app.contact', {
url: "/contact",
views: {
'menuContent': {
templateUrl: "templates/contact.html"
}
}
})
.state('app.reservations', {
url: "/reservations",
views: {
'menuContent': {
templateUrl: "templates/reservations.html"
}
}
})
.state('app.details', {
url: "/details",
views: {
'menuContent': {
templateUrl: "templates/details.html"
}
}
})
.state('app.data', {
url: "/data",
views: {
'menuContent': {
templateUrl: "templates/data.html"
}
}
})
.state('app.offer', {
url: "/offer",
views: {
'menuContent': {
templateUrl: "templates/offer.html"
}
}
})
.state('app.register', {
url: "/register",
views: {
'menuContent': {
templateUrl: "templates/register.html"
}
}
})
.state('app.about', {
url: "/about",
views: {
'menuContent': {
templateUrl: "templates/about.html"
}
}
});
// if none of the above states are matched, use this as the fallback
$urlRouterProvider.otherwise('/home');
});
search.html
<ion-content class="search_content padding" scroll="false" style="background-
color: darkred">
<div class="tab-content animated fadeInUp">
<ion-scroll direction="y" style="height: 100%">
<iframe name="chatFrame" id="iframe"
class="iframe" style="BORDER-BOTTOM: medium none; BORDER-LEFT: medium none;
BORDER-TOP: medium none; BORDER-RIGHT: medium none;width:100%;min-
height:290px" src="https://example.com" align="top" scrolling="auto">
</iframe>
</ion-scroll>
</div>
您可以在控制器中维护一个标志,如下所示。
if (navigator.onLine) {
$scope.isNetworkAvailable = true;
}
else{
$scope.isNetworkAvailable = false;
}
在 HTML 中使用 isNetworkAvailable 标志,如下所示
<iframe ng-if="isNetworkAvailable " name="chatFrame" id="iframe"
class="iframe" style="BORDER-BOTTOM: medium none; BORDER-LEFT: medium none;
BORDER-TOP: medium none; BORDER-RIGHT: medium none;width:100%;min-
height:290px" src="https://example.com" align="top" scrolling="auto">
</iframe>