私のアプリケーションにはエラーはありません。なぜ真っ白な画面が表示されるのでしょうか?
この事象が発生しうる理由がいくつかあります。もしあなたがフォーラム上で解決策を見つけられなかった場合、これらを確認して下さい:
- ポリフィルには古い android のブラウザ/バージョンは含まれない
@angular/cli@7.3
以上のプロジェクトの場合、ポリフィルは自動的に含まれます。その前に作成されたプロジェクトでは、ポリフィルを手動で有効にする必要があります。
src/polyfills.ts
にて、Android 4.4 をサポートするために ES6 ポリフィルをすべて有効にする必要があります。
あるいは、プロジェクトを更新して、@angular/cli
パッケージと @angular-devkit
パッケージの最新リリースを使用し、angular.json
のビルドオプションオブジェクトに es5BrowserSupport
オプションを含めることもできます:
"input": "src/global.scss"
}
],
- "scripts": []
+ "scripts": [],
+ "es5BrowserSupport": true
},
"configurations": {
"production": {
これにより、古いブラウザに必要なポリフィルが自動的に追加されます。
なぜ私のカスタムコンポーネント/ディレクティブは動作しないのでしょうか?
あなたが確認できるものがいくつか存在します。
- セレクタにスペルミスがない
- 属性、要素、クラスとして、セレクタを正確に使用している
- セレクタの構文が適切:
- 属性セレクタの場合は
[attr]
- 要素セレクタの場合は
element
- クラスセレクタの場合は
.class
以下に、属性セレクタの例を挙げます:
@Directive({
selector: '[my-dir]'
})
class MyDir {
constructor() {
console.log('I'm alive!');
}
}
@Component({
template: `<div my-dir>Hello World</div>`,
directives: [MyDir]
})
class MyPage { }
一般的に、我々は標準的なクリックイベントを要素に追加する場合は (click)
のみを勧めています。
これには <button>
や <a>
要素も含まります。これにより、
画面を読むときに各要素がクリック可能であることを伝えることができるため、アクセシビリティを
向上します。
しかしながら、おそらくあなたは通常はなクリックできない要素に (click)
イベントを要素に追加することを
求められるかもしれません。もしあなたがこれを実行すると、要素をクリックしてイベントが発火するまで
300ms
の遅延が発生するかもしれません。この遅延を改善するには、あなたは
要素に tappable
属性を追加することができます。
<div tappable (click)="doClick()">I am clickable!</div>
Why does Angular change detection run very frequently when my components are initializing?
Angular uses a library called zone.js
which helps it determine when to run change detection.
As of zone.js 0.8.27
, certain APIs for Web Components also cause change
detection to run. This can have the undesirable side effect of your app
slowing down when a large number of components are initializing.
To prevent this from happening, the zone.js flag that manages this portion of
change detection can be disabled. In the src
directory of your application,
create a file called zone-flags.ts
. Place the following code into the file:
(window as any).__Zone_disable_customElements = true;
The zone-flags.ts
file then needs to be imported into your application's
polyfills.ts
file. Be sure to import it before zone.js
is imported:
...
import './zone-flags.ts';
import 'zone.js/dist/zone';
...
This change will only affect applications that depend on zone.js 0.8.27
or
newer. Older versions will not be affected by this change.
This flag is automatically included when creating an Ionic app via
the Ionic CLI.
あなたの開発中のある時点で、Cordova プラグインを呼び出そうとしますが、
警告:
[Warning] Native: tried calling StatusBar.styleDefault, but Cordova is not
available. Make sure to include cordova.js or run in a device/simulator
(app.bundle.js, line 83388)
これは、あなたがネイティブプラグインを呼び出そうとしますが、Cordova プラグインが利用できないときに発生します。
ありがたいことに、Ionic Native はエラーの代わりに良い警告を表示してくれます。
他のケースでは、プラグインが Ionic Native を介して利用されない場合、プラグインは
より曖昧な警告を表示することができます。
EXCEPTION: Error: Uncaught (in promise): TypeError: undefined is not an object
(evaluating 'navigator.camera.getPicture')
もしこれが発生した場合は、そのプラグインを実機かシミュレーターでテストしてみてください。
あなたは provider をすべてのコンポーネントで利用可能にしたいので、すべてのコンポーネントに provider を注入した場合、
provider の複数のインスタンスが生成されます。
子コンポーネントで使用できるようにする場合は、親コンポーネントに一度だけ Provider を
注入する必要があります。
let id = 0;
export class MyService {
id: number;
constructor() {
this.id = id++;
}
}
@Component({
selector: 'my-component',
template: 'Hello World',
providers: [MyService],
})
class MyComp {
constructor(s: MyService) {
console.log('MyService id is: ' + s.id);
}
}
@Component({
template: '<my-component></my-component>',
providers: [MyService],
directives: [MyComp],
})
class MyApp {
constructor(s: MyService) {
console.log('MyService id is: ' + s.id);
}
}