我正在实现一个客户数据库,让我可以使用 ASP.NET MVC 和 javascript (jQuery) 搜索用户和公司、浏览和编辑他们的详细信息以及许多其他事情。
每当发生 post 或 get 时,我都会通过 jQuery.load 执行此操作并将 PartialView 插入到 DOM 中。
一些局部 View 包括表单。我也希望它们是 ajax 表单,因此那些部分 View 具有 document.ready 处理程序,可将表单转换为 ajax 表单(通过 jquery.form)。
一开始我是在将部分 View 插入 DOM 的回调/代码中处理这个问题。然而,这导致了一个包含大量引用不同页面的 javascript 函数的大脚本。我通过将脚本插入相应页面来重构大型 javascript。
现在代码更流畅(我的 OnXXXPartialView 处理程序少了很多)并且代码整齐地位于它所属的局部 View 中。这些文件中的大多数只包含 3-4 行 javascript 代码,因此开销并不大。
如此有效,我不仅向文档 DOM 添加元素,而且有时我还添加了一段 javascript。在实践中这很好用,但似乎Firebug can't debug the dynamically loaded scripts .
当然有 Firebug 问题的解决方法,但我想知道我的架构是否可能是这里的真正罪魁祸首。你把属于部分 View 的javascript放在哪里?有什么最佳实践吗?
最佳答案
如果您正在经历在局部 View 中包含 javascript 的麻烦,我会切换到仅在您的 ajax 调用中返回 JSON,这样您就可以在客户端处理所有事情。不过,我承认我总是更喜欢这种方法。
至于最佳实践,我一直认为在 ajax 调用中返回生成的 html 而不是 json 是不好的,但这就是我的看法(不是打击你,这是个人选择)。显然,微软并不认为它是不好的做法,因为他们专门内置了支持它的功能。无论如何,我不会考虑在您的 html 中包含 javascript 比首先发送回 html 更糟糕。
不过我很好奇,javascript 中有什么?
编辑: 具体来说,我赞成进行 ajax 调用以获取 json,然后使用客户端 JS 构建该“部分 View ”并将其插入 dom。与进行 ajax 调用以获取服务器为客户端呈现的 html 然后插入到 dom 中相反。
Some partial views include forms. I want those to be ajax forms as well, so those partialviews have document.ready handlers that turn the forms into ajax forms (via jquery.form).
我认为您可以在将部分 View 插入 dom 的回调/代码中处理此问题。
编辑:如果它有序、高效、组织良好并且适合您,那么我会坚持使用它。将所有美好和紧凑的东西都放在局部 View 中的想法绝对有吸引力,所以我不会太担心违反任何最佳实践。我唯一担心的是 JS 可能是可重用的,如果您一遍又一遍地插入相同的脚本,就会出现这种情况。但在这种情况下,听起来你正在进行大量的划分,所以我会坚持使用它,除非你可以概括你的脚本并将它们包含在你的 JS 的其余部分中。
关于javascript - 返回包含 javascript 的部分 View 是不好的做法吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/863436/
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我是rails的新手,想在form字段上应用验证。myviewsnew.html.erb.....模拟.rbclassSimulation{:in=>1..25,:message=>'Therowmustbebetween1and25'}end模拟Controller.rbclassSimulationsController我想检查模型类中row字段的整数范围,如果不在范围内则返回错误信息。我可以检查上面代码的范围,但无法返回错误消息提前致谢 最佳答案 关键是您使用的是模型表单,一种显示ActiveRecord模型实例属性的表单。c
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出
为什么以下不同?Time.now.end_of_day==Time.now.end_of_day-0.days#falseTime.now.end_of_day.to_s==Time.now.end_of_day-0.days.to_s#true 最佳答案 因为纳秒数不同:ruby-1.9.2-p180:014>(Time.now.end_of_day-0.days).nsec=>999999000ruby-1.9.2-p180:015>Time.now.end_of_day.nsec=>999999998
在Ruby1.9.3(可能还有更早的版本,不确定)中,我试图弄清楚为什么Ruby的String#split方法会给我某些结果。我得到的结果似乎与我的预期相反。这是一个例子:"abcabc".split("b")#=>["a","ca","c"]"abcabc".split("a")#=>["","bc","bc"]"abcabc".split("c")#=>["ab","ab"]在这里,第一个示例返回的正是我所期望的。但在第二个示例中,我很困惑为什么#split返回零长度字符串作为返回数组的第一个值。这是什么原因呢?这是我所期望的:"abcabc".split("a")#=>["bc"