我正在使用角度js构建应用程序,它具有在用户在文本区域上编写html后直接显示HTML预览的功能。但是当用户在文本区域上输入样式时,我坚持如何隔离 html 本身的 css。预览中的 HTML css 不应覆盖主 css。
这是我的剪纸:
显示 html 预览的指令:
app.directive('htmlViewer', ['$sce', function($sce){
return {
scope: {
htmlViewer: '=',
},
template: "<div ng-bind-html='trustedHtml'></div>",
link: function($scope, iElm, iAttrs, controller) {
$scope.updateView = function() {
$scope.trustedHtml = $sce.trustAsHtml($scope.htmlViewer);
}
$scope.$watch('htmlViewer', function(newVal, oldVal) {
$scope.updateView(newVal);
});
}
};
}]);
和视图类似:
<div html-viewer="myHtmlModel.content"></div>
我应该怎么做才能实现该功能?因此,html预览及其css不会覆盖主应用程序的css。对不起,我对棱角相对陌生。
编辑这是我在文本区域上的示例html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta name="viewport" content="width=device-width" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Template</title>
<style>
/* -------------------------------------
GLOBAL
------------------------------------- */
body {
-webkit-font-smoothing: antialiased;
-webkit-text-size-adjust: none;
width: 100%;
min-width:300px;
max-width:680px;
margin:0 auto;
height: 100%;
background:#f6f6f6!important;
}
</style>
</head>
<body bgcolor="#f6f6f6">
<!-- content -->
<div class="content">
Lorem ipsum dolor sit amet
</div>
<!-- /content -->
</body>
</html>
非常感谢您的帮助或建议。
谢谢
溶液
最后,我正在使用iframe来解决这个问题。通过创建新指令并与前一个指令相结合。
app.directive('framePreview', function($compile) {
return function($scope, $element) {
var $body = angular.element($element[0].contentDocument.body),
template = $compile('<div html-viewer="myHtmlModel.content"></div>')($scope);
$body.append(template);
};
});
那么在我看来:
<iframe frame-preview="" width="100%" height="500px"></iframe>
可以使用 iframe 代替?像jsFiddle,jsBin这样的网站也使用iframe进行代码预览。