在ionic应用中打开外部网站(使用InAppBrowser插件)

在安卓上试了一下,如果直接window.open(url), 在app中点击外部链接没有任何反应。

安装https://github.com/apache/cordova-plugin-inappbrowser
执行命令:
ionic plugin add cordova-plugin-inappbrowser

简而言之,就是用window.cordova.InAppBrowser.open替换window.open

步骤:

1. 在应用程序启动的时候判断window.cordova是否存在如果是重写window.open方法

2. 用ng-click="openLink(story.url)" 替换先前的href

3. 在$scope中定义openLink方法。

4.  连上手机, 运行ionic run android测试 

文件一: www/index.html

<div class="list">
      <a ng-click="openLink(story.url)" class="item item-thumbnail-left item-text-wrap"
         ng-repeat="story in stories track by story.id">
        <img ng-src="{{story.thumbnail}}" ng-if="story.thumbnail.startsWith('http')"/>

        <h2>{{story.title}}</h2>

        <p>
          <span am-time-ago="story.created_utc" am-preprocess="unix"></span> - {{story.domain}}
        </p>
      </a>
    </div>



文件二: www/js/app.js

(function () {
  var app = angular.module('myreddit', ['ionic', 'angularMoment']);
  app.controller('RedditCtrl', function ($http, $scope) {
    $scope.stories = [];

    function loadStories(params, callback) { 。。。
    }

    $scope.loadOlderStories = function () {。。。
    }

    $scope.loadNewerStories = function () {。。。
    }

    $scope.openLink = function (url) {
      window.open(url, '_blank');
    }

  });
  app.run(function ($ionicPlatform) {
    $ionicPlatform.ready(function () {
     。。。
      if (window.cordova && window.cordova.InAppBrowser) {
        window.open = window.cordova.InAppBrowser.open;
      }
。。。
    });
  })

})();





转载于:https://my.oschina.net/uniquejava/blog/525304

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值