首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在使用Ionic3时获取不支持的错误

在使用Ionic3时获取不支持的错误
EN

Stack Overflow用户
提问于 2017-05-15 11:45:07
回答 1查看 3K关注 0票数 5

我勒死是为了能抓到这个错误。在桌面上,此代码将引发此NotSupportedError

我通常在铬上调试。

以下是代码:

代码语言:javascript
运行
复制
import {Component} from "@angular/core";
import {ScreenOrientation} from "@ionic-native/screen-orientation";

@IonicPage()
@Component({
  selector: 'page-loading',
  templateUrl: 'page-loading.html',
})
export class PageLoading {

  constructor(private screenOrientation:ScreenOrientation) {}

  ionViewDidLoad() {
    console.log('ionViewDidLoad PageLoading');

    try{
        this.screenOrientation.lock(this.screenOrientation.ORIENTATIONS.PORTRAIT).then(()=>{
          console.log('lock');
        });
    }catch(e){
      console.warn('No cordova.js')
    }

  }

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-05-15 12:30:32

您可以创建一个类来模拟在docs 这里中描述的离子本机类。

代码语言:javascript
运行
复制
class ScreenOrientationMock extends ScreenOrientation {
  lock(type) {
    return new Promise((resolve, reject) => {
      resolve("locked");
    })
  }
}

ngModule中的提供者列表中,它应该使用模拟类而不是实际的离子本机类。

代码语言:javascript
运行
复制
providers: [..
    { provide: ScreenOrientation, useClass: ScreenOrientationMock }
 ]

这将返回您在resolve中为ionic serve期间的屏幕定向设置的任何内容。

一旦它在设备中运行,您就可以删除它。

编辑:

还有另一种抑制错误的可能性,所以在结束时您将没有什么可做的:

代码语言:javascript
运行
复制
if(this.platform.is('cordova')){
  this.platform.ready().then(()=>{
   this.screenOrientation.lock(this.screenOrientation.ORIENTATIONS.PORTRAIT);
  })
}
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43978662

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档