[解決済み] AngularJSのコントローラからビューにHTMLを挿入する
2022-03-18 03:42:56
質問
を作成することは可能ですか? HTML フラグメントを作成し、このHTMLをビューに表示させることができますか?
これは、一貫性のないJSON blobを、ネストされた
id: value
のペアを作成します。そのため
HTML
がコントローラ内に作成され、それを表示させたいと考えているところです。
モデルプロパティを作成しましたが、これをビューでレンダリングする際に HTML .
更新情報
どうやら、angularが作成したHTMLを引用符で囲んだ文字列としてレンダリングしていることが問題の原因のようです。これを回避する方法を探します。
コントローラの例 :
var SomeController = function () {
this.customHtml = '<ul><li>render me please</li></ul>';
}
ビューの例 :
<div ng:bind="customHtml"></div>
を与える。
<div>
"<ul><li>render me please</li></ul>"
</div>
解決方法は?
Angular 1.xの場合
ng-bind-html
をHTML内に記述してください。
<div ng-bind-html="thisCanBeusedInsideNgBindHtml"></div>
この時点で、あなたは
attempting to use an unsafe value in a safe context
エラーになるので
ngSanitize
または
$sce
で解決します。
$sce
使用方法
$sce.trustAsHtml()
をコントローラで実行し、html 文字列を変換します。
$scope.thisCanBeusedInsideNgBindHtml = $sce.trustAsHtml(someHtmlVar);
ngSanitize
2つのステップがあります。
-
angular-sanitize.min.jsリソースをインクルードする、すなわち。
<script src="lib/angular/angular-sanitize.min.js"></script>
-
jsファイル(コントローラや通常app.js)で、ngSanitizeをインクルードする、すなわち。
angular.module('myApp', ['myApp.filters', 'myApp.services', 'myApp.directives', 'ngSanitize'])
関連
-
vueが定義するプライベートフィルタと基本的な使い方
-
Vueのフォームイベントのデータバインディングの説明
-
[解決済み] 配列に特定のインデックスで項目を挿入する方法 (JavaScript)
-
[解決済み] 入力フィールドから属性を読み込むと、HTMLエンコーディングが失われる
-
[解決済み] あるAngularJSのコントローラが別のコントローラを呼び出すことはできますか?
-
[解決済み] AngularJSでコントローラを2回実行する場合の対処法
-
[解決済み] 部分テンプレートとテンプレートの複雑なネスト
-
[解決済み] 子コントローラから親スコープにアクセスするAngularJS
-
[解決済み】AngularJSコントローラのライフサイクルは何ですか?
-
[解決済み] AngularJS 1ページ内に複数のng-appを配置する。
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
元のイベントが実行されなかった後に要素を追加するためのjQueryソリューション
-
JavaScriptのクロージャの説明
-
vueのグローバルがscss(mixin)を導入。
-
vue+webrtc(Tencent cloud)ライブ機能の実践を実現するために
-
vueが定義するプライベートフィルタと基本的な使い方
-
vueのプロジェクトでモックを使用する方法を知っていますか?
-
Vueの一般的な組み込みディレクティブの説明
-
[解決済み】ローカルファイルを開くことができません - Chrome: ローカルリソースの読み込みが許可されていない
-
[解決済み】TypeError: Router.use() はミドルウェアの関数を要求しているが、Object を取得した。
-
nodejs unhandledPromiseRejectionWarning メッセージ