【发布时间】:2015-05-24 20:32:19
【问题描述】:
<div id="block">
<p>some value</p>
<div>tons of stuff</div>
<li>etc</li>
</div>
在 jQuery 中,我们可以做到var getHtml = $("#block").html();,但我们如何在 AngularJS 中做到这一点?我只知道我们可以使用 ng-model 进行绑定,但是我们是否在数百个 HTML 标签上声明了许多 ng-model?
澄清一下:我想将生成的 HTML 保存到我的本地存储中,我不想混淆 AngularJS 和 jQuery。
【问题讨论】:
-
使用 Angular 时应该问自己的第一个问题是,我为什么要直接访问 DOM 元素?你在这里的目标是什么?如果是修改视图,则应通过修改要更改的视图的 $scope.xxx 值来处理。如果您仍然想要访问,您可以通过在控制器中执行 $("#someid", $element) 来混合 angularjs 和 jquery。
-
@MarvinSmit 我想将一些值(html)存储到我的本地存储中。
-
您应该只存储数据,而不是呈现数据的 HTML(数据和模板的混合)。 *除非“HTML”是编辑器控件的内容(这会使 HTML 成为“数据”)。
-
我认为您应该阅读 MVC/MVP/MVVM 模式。听起来您使用 angular 是因为您“必须”,而不是因为您看到应用模式的好处。
-
Marvin 我同意你的观点,这听起来与 angular 的含义背道而驰,但我们不知道他的问题的范围是什么,所以在不了解更多信息的情况下说使用 .html 是不好的问题是错误的。
标签: javascript jquery html angularjs