草庐IT

javascript - 使用参数缓存 URL View /状态

coder 2024-05-12 原文

我正在使用 Cordova 和 AngularJS 制作移动应用程序。目前我已经安装了用于路由的 ui-router,但我愿意接受任何其他路由选择。

我的愿望:我想缓存某些绑定(bind)了参数的 View 。换句话说,我想缓存路径(或页面)。

示例情况:假设我们看到一些仪表板页面,单击重定向到路径 book/2 的书籍封面。此路径是第一次加载到应用程序中。路由器从 HomeController 重定向到 BooksController(不管名字是什么)。现在,BooksController 为给定的 $stateParams(书籍 id = 2)加载数据,并创建包含所选书籍信息的 View 。

在这种情况下我想要什么:

  1. 我回到仪表板页面 - 它已经加载(缓存?)
  2. 我再次选择第 2 本书
  3. Controller 或路由器注意到关于这本书的数据已经加载
  4. View 没有被重新创建,而是从缓存中获取

其实我访问的所有内容,最好是根据路径缓存起来。预加载也很酷。

原因:性能。当我打开一些书单时,我希望它能快速显示。每次创建 View 时,页面更改的动画看起来很糟糕(不流畅)。

如有任何帮助,我们将不胜感激。

编辑:

首先,由于我认为这是许多移动 HTML 应用程序程序员的普遍问题,因此我想准确说明一些信息:

  1. 我不是在寻找黑客,而是在如果可能的情况下寻找一个清晰的解决方案。
  2. View 中的数据使用 AngularJS,所以是的,ng-bindng-repeat 等东西。
  3. 缓存 数据DOM 元素 都需要。据我所知,浏览器的布局操作并不像重新创建整个 DOM 树那么昂贵。重绘不是我们可以省略的。
  4. 拥有独立的 Controller 是很自然的事情。因为我可以不带它就离开,所以我无法想象它是如何工作的。

我有一些半解决方案,但我会严格遵守我的愿望。

解决方案 1.

将所有 View 放入一个文件中(我可能会使用 gulp builder 来完成)并使用 ng-show。这是最简单的解决方案,我相信任何了解 AngularJS 的人都不会考虑它。

一个不错的技巧(来自@DmitriZaitsev)是创建一个辅助函数来根据当前位置路径显示/隐藏元素。

优点:

  1. 很简单。
  2. 某种预加载功能。

缺点:

  1. 所有 View 都必须在一个文件中。不要问为什么不方便。
  2. 因为都是关于移动设备的,所以有时我想“清除”内存。我能想到的唯一方法是从 DOM 中删除这些子项。脏但还可以。
  3. 我不能同时缓存/book/2 和/book/3。我将不得不在某些模板之上为每个绑定(bind)了参数的 View 动态创建 DOM 子级。

解决方案2。

使用 ui-router-extras 中的粘性状态和 future 状态这太棒了。

优点:

  1. 分开的 View 。
  2. 非常清晰的用法,非常简单,因为它只是一个ui-router的插件。
  3. 可以创建动态子状态。因此可以缓存 book1book2 但我不确定 book/1book/2

缺点:

  1. 同样,我不确定,但我没有找到缓存/元组(view, parameters) 的示例。除此之外,它看起来很酷。

最佳答案

这正是我必须为我的网站解决的问题 33hotels.com .您可以检查它并使用选项卡“过滤器”和“过滤器列表”(对应于不同的路由),并看到 View 立即更新,没有任何延迟!

我是怎么做到的?这个想法非常简单 - 摆脱路由器!

为什么?因为路由器的工作方式是在每次路由更改重新编译 View 。是的,Angular 会缓存 Template 但不会缓存填充了数据的编译 View 。即使数据不改变!结果,我以前用Router的时候,总感觉开关卡顿, react 迟钝。每次我都能注意到烦人的延迟,虽然只有几分之一秒,但仍然很明显。

现在我使用的解决方案是什么?不要重新编译您的 View !始终将它们保存在您的 DOM 中!然后使用 ng-hide/ng-show 根据路线隐藏/显示它们:

<div ng-show="routeIs('/dashboard')">
    <-- Your template for Dashboard -->
</div>

<div ng-show="routeIs('/book')">
    <-- Your template for Book -->
</div>

然后在您的 Controller 中创建一个函数 routeIs(string) 来测试 $location.path() 是否匹配 string,或者以 string 开头,因为我正在使用它。这样我仍然可以获得所有路径的 View ,例如 /book/2。这是我正在使用的功能:

$scope.routeBegins = function () {
    return _.some(arguments, function (string) {
           return 0 === $location.path().indexOf(string);               
    });
};            

因此无需巧妙地使用缓存 - 只需将其保存在 DOM 中即可。它将为您缓存您的 View !

最棒的是——只要你的数据发生变化,Angular 就会立即更新你 DOM 中的所有 View ,甚至是隐藏的 View !

为什么这么棒?因为,作为用户,我不需要在我想看到结果的那一刻等待所有的解析和编译。我想单击选项卡并立即查看我的结果!为什么网站要等我点击它然后然后在我等待的时候开始所有的重新编译?尤其是以前可以轻松完成此操作时,在我的计算机闲置期间。

有什么缺点吗?我能想到的唯一真实的方法是用更多的 DOM 元素加载内存。但是,我的 View 的这个实际字节大小可以忽略不计,例如比较包含所有 JS、CSS 和图像。

另一个可能但可以避免的缺点是隐藏 View 的重新编译成本。这是您可以变得聪明并根据当前路线避免计算量大的部分的地方。 此外,您无需重新编译整个 View ,只需重新编译受数据更改影响的部分,这也降低了计算成本。

我发现每个人都在使用路由并且似乎完全没有意识到(或不知道)这个问题是非常了不起的。

关于javascript - 使用参数缓存 URL View /状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26591335/

有关javascript - 使用参数缓存 URL View /状态的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 使用 RubyZip 生成 ZIP 文件时设置压缩级别 - 2

    我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看ruby​​zip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  5. ruby - 在 Ruby 中使用匿名模块 - 2

    假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于

  6. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  7. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  8. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  9. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  10. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

随机推荐