情景:
在使用 rail 中的 自动完成功能 auto_complete_field时,假若返回的页面中有 javascript脚本,那它将不会被返回。 必需把它用 javascript_function 方法进行改写。
a.rhtml 中 render _b.rhtml 页面。 在_b.rhtml中如果包含了 javascript脚本,则不能被render到a.rhtml中。
我在_b.rhtml中用了auto_complete_field来对用户输入进去提示。因为auto_complete_result 返回的已经是javascript脚本了,就不能把javascript发送给客户端。
解决方法:
在application_helper.rb中覆盖此方法:不返回javascript脚本,把结果放到_b.rhtml中 用javascript_function方法把脚本输出到客户端。
def auto_complete_field_no_javascript_tag(field_id, options = {})
function = "var #{field_id}_auto_completer = new Ajax.Autocompleter("
function << "'#{field_id}', "
function << "'" + (options[:update] || "#{field_id}_auto_complete") + "', "
function << "'#{url_for(options[:url])}'"
js_options = {}
js_options[:tokens] = array_or_string_for_javascript(options[:tokens]) if options[:tokens]
js_options[:callback] = "function(element, value) { return #{options[:with]} }" if options[:with]
js_options[:indicator] = "'#{options[:indicator]}'" if options[:indicator]
js_options[:select] = "'#{options[:select]}'" if options[:select]
js_options[:paramName] = "'#{options[:param_name]}'" if options[:param_name]
js_options[:frequency] = "#{options[:frequency]}" if options[:frequency]
{ :after_update_element => :afterUpdateElement,
:on_show => :onShow, :on_hide => :onHide, :min_chars => :minChars }.each do |k,v|
js_options[v] = options[k] if options[k]
end
function << (', ' + options_for_javascript(js_options) + ')')
function
end
分享到:
相关推荐
JsRender 是一个轻量级但功能强大的JavaScript模板引擎,由Microsoft的前员工 Boris Moore开发。这个库旨在提供一种简洁、高效的方式来动态渲染HTML内容,尤其适用于构建用户界面和数据绑定。JsRender 包含了两个...
**jQuery-jsrender.js** 是一个基于 jQuery 的高性能 JavaScript 模板引擎,它的设计目标是提供一种灵活、高效的方式来渲染和管理HTML视图。这个插件主要用于处理数据绑定和动态渲染,使得开发者能够在不刷新整个...
5. **性能优化**: JsRender 通过编译模板为JavaScript函数,提高了渲染效率,减少了DOM操作,从而提升页面性能。 **JsRender的循环迭代** 在提供的"JsRender的应用,提供一个循环迭代的例子"中,我们可以看到如何...
为了优化性能和兼容性,htmlrender库可能还实现了对CSS和JavaScript的支持,允许用户在HTML中使用样式和交互,进一步提升生成内容的复杂性和美观度。同时,对于网络资源的处理,比如图片和字体,htmlrender可能提供...
JSRender是一个轻量级但功能强大的JavaScript模板引擎,它在前端项目中被广泛使用,特别是在构建动态Web应用时。这个压缩包“jsrender.zip”包含了JSRender的源码,这使得开发者可以深入了解其工作原理,并在自己的...
`jQuery JSRender` 是一款高效且功能强大的JavaScript模板引擎,它是jQuery插件家族的一员,专为构建动态数据驱动的Web界面而设计。该库允许开发者通过简洁易读的语法创建复杂的HTML模板,从而在不涉及大量DOM操作的...
Vue.js是一个流行的前端JavaScript框架,用于构建用户界面和单页应用程序。Element UI是Vue.js的一个组件库,提供了许多预定义的UI组件,比如按钮、表单、表格等,以便快速构建界面。render函数在Vue.js中扮演着重要...
2. **功能强大**:JsRender支持条件语句、循环结构、函数调用等多种复杂逻辑,能够满足大多数模板渲染需求。 3. **可扩展性**:通过自定义标签和辅助函数,开发者可以扩展JsRender的功能,适应特定项目的需求。 4....
- Render sites to 2D or 3D objects - Chromium backend; best-in-class support for: HTML, CSS, and JavaScript - Call JavaScript1 from Unity - Call Unity from JavaScript1 - Transparent or opaque ...
在Node.js项目中,EJS(Embedded JavaScript)是一种流行的模板引擎,它允许开发者将动态数据嵌入到HTML中,从而创建可复用且易于维护的页面。EJS模板库简化了服务器端渲染的过程,尤其适合构建Web应用。下面将详细...
调用`htmlRender`方法将数据绑定到指定的DOM元素,实现了动态渲染。 五、总结 HTMLRender作为一款jQuery插件,为JavaScript数据绑定提供了便利,通过高效的模板引擎机制,简化了前端开发中的动态内容生成。无论是...
此外,`render` 函数还可以利用 JavaScript 的全部能力,包括条件语句、循环、函数调用等,提供更高的灵活性。例如,我们可以根据 `level` 的值动态添加额外的类或属性。 总的来说,Vue 的 `render` 函数提供了对...
来调用对应的百度地图JavaScript Api的方法,比如在componentDidMount和componentDidUpdate的时候在地图上添加覆盖物,componentWillUnmount的时候移除覆盖物,React对应的render渲染函数模块返回的是null。...
JavaScript是一种广泛应用于网页和网络应用的脚本语言,尤其在前端开发中占据核心地位。控件开发是JavaScript应用中的重要部分,它涉及到UI组件的创建和功能实现。在这个主题中,“javascript控件开发之继承关系”...
【JavaScript源代码】如何创建自己的第一个React页面 React是一个由Facebook开发的JavaScript库,主要用于构建用户界面。不同于传统的JavaScript库,React提供了一种声明式的编程方式,使得开发者能更直观地描述UI...
JavaScript是一种广泛应用于网页和网络应用开发的脚本语言,它在浏览器环境中运行,为用户提供动态交互体验。在本文中,我们将深入探讨如何使用JavaScript来创建一个可展开和可收缩的树形结构。树形结构是一种数据...
在函数内部,我们可以使用`table.render()`方法来创建表格,并传入配置对象,比如表格ID、列定义、数据源等。 2. 数据源:这里提到的"调用json获取数据"是指使用Ajax从服务器获取JSON格式的数据。在Layui中,这通常...
Vue.js 是一个流行的前端JavaScript框架,它提供了许多高级特性来帮助开发者构建复杂的用户界面。其中,`render`函数是Vue.js中的一个核心概念,它允许我们以编程方式生成虚拟DOM,提供更高的灵活性和性能优化的可能...
总结来说,res.render()适合用来渲染模板,并返回一个完整的HTML页面,它适合于页面渲染的场景。而res.send()适用于需要快速返回简单数据的场景,例如API响应。在选择使用哪种方法时,应根据你的实际需求以及希望...