- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 drupal 中开发一个项目,该项目允许我拥有可视书签屏幕截图(想想zootool.com)。我将每个屏幕截图放在一个使用 jQuery 进行排序的网格中。这一切都工作正常,我可以将所有图像按我希望的顺序排序。唯一的问题是我无法保存刚刚更改的位置/订单。
我使用“权重”模块为每个屏幕截图分配默认值,这是使用按此“权重”排序的 View 输出的。因此,当我使用 jQuery 移动节点时,我需要一种机制来更新/保存所有节点的权重顺序。
目前我有 jQuery 代码,可以输出带有新订单的警报框:
//Draggable boxes
$(function() {
$( ".sortable-nodes" ).sortable({
placeholder: "ui-state-highlight",
opacity: 0.7,
update: function(event, ui) {
var result = $(this).sortable('toArray');
alert(result);
}
});
});
我的问题是这样的:Drupal 是否已经有一个页面可以用来通过 jQuery.post 更新节点,还是我必须制作自己的页面来保存节点?另外,这是正确的方法还是有更好的方法在移动可排序框后更新/保存节点位置?
非常感谢!
最佳答案
好的,我想我应该用我找到的解决方案来跟进我的问题。它可能会帮助其他人。它很大程度上基于 googletorp 对此处发布的非常相似的问题的回答:Drupal 6/jQuery Ajax update a field .
步骤 1.0 创建一个新模块。我创建了一个简单的 updatemynode.info 文件和 updatemynode.module 文件。
1.1 updatemynode/updatemynode.module包含两个函数。
function updatepos_menu() {
$items = array();
$items['update_positions'] = array(
'page callback' => 'update_node_position',
'type' => MENU_CALLBACK,
'access callback' => TRUE,
'access arguments' => array('access content'),
);
return $items;
}
这是模块中创建 URL www.mywebsite.com/update_positions 的第一个函数,该函数调用 php 函数“update_node_position”。 (见下文)
1.2 updatemynode/updatemynode.module第二个函数是:
function update_node_position() {
// Create an array from the passed string
$neworder = explode(",", $_POST['theorder']);
// For each array entry, redo their node weight (which Views sorts on)
foreach ($neworder as $key => $value){
$node = node_load($value);
$node->node_weight = ($key+1);
node_save($node);
}
}
为了简洁起见,我删除了任何错误检查,它只是完成了一个功能,仅此而已。基本上,它执行以下操作: A. 搜索 $_POST['theorder'] 变量(其中包含我的应用程序中的 NID 字符串),使用 php 'explode' 将字符串转换为数组并分配给 $neworder。 B. 对于新数组的每个条目,使用值 (NID) 加载该节点。 C. 我正在使用“重量”模块来创建排序。 $node->node_weight = ($key+1); line 将数组 1、2、3、4 等中的位置分配给节点权重。 (从而创建订单)。 D. 保存节点并对数组中的每个条目重复此操作。
2.0 我有一个 main_javascript.js 文件,它附加到我的所有 drupal 页面上。该 javascript 文件包含以下代码:
$(function() {
$( ".sortable-nodes" ).sortable({
placeholder: "ui-state-highlight",
opacity: 0.7,
update: function(event, ui) {
// Create result variable that contains array order.
var result = $(this).sortable('toArray');
// Run AJAX function with RESULT data to update_positions page
$.ajax({
type: "POST",
url: "/update_positions",
// Pass the RESULT array
data: { theorder : [result]},
});
}
});
这是 jQuery 的关键,它做了一些事情:
2.1 标记为 .sortable-nodes 的对象(在我的例子中是一个 DIV)使用 jQuery 'sortable' 方法进行排序。当我单击并拖动 DIV 时,它将执行以下操作:
2.2 在每个可排序 DIV 之间使用 CSS 类“ui-state-highlight”。
2.3 将不透明度降低到70%。
2.4 一旦位置更改,它将运行“更新”事件。
2.5 “update”事件将创建一个名为“result”的变量,其中包含所有可排序对象节点 id 的字符串。 (例如113,114,115,116,117等...)
2.6 .ajax 方法运行并被告知将 POST 请求发送到/update_positions URL(之前在 updatemynode/updatemynode.module 文件中创建)并传递名为“theorder”的 $_POST 变量,其中包含字符串“结果'。一旦字符串“result”被传递到 URL,模块函数 update_node_position() 就会使用这个字符串并按照上面的解释发挥它的魔力。
3.0 我在页面上的结果是使用 View 按节点权重排序的。因此,当页面重新加载时,顺序应该与您使用 AJAX 调用订购的方式保持相同(因为 node_weight 已更新)。
希望这对某人有帮助。欢迎任何问题/意见!
关于Drupal 中的 Jquery 持久可排序对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7596120/
我的一位教授给了我们一些考试练习题,其中一个问题类似于下面(伪代码): a.setColor(blue); b.setColor(red); a = b; b.setColor(purple); b
我似乎经常使用这个测试 if( object && object !== "null" && object !== "undefined" ){ doSomething(); } 在对象上,我
C# Object/object 是值类型还是引用类型? 我检查过它们可以保留引用,但是这个引用不能用于更改对象。 using System; class MyClass { public s
我在通过 AJAX 发送 json 时遇到问题。 var data = [{"name": "Will", "surname": "Smith", "age": "40"},{"name": "Wil
当我尝试访问我的 View 中的对象 {{result}} 时(我从 Express js 服务器发送该对象),它只显示 [object][object]有谁知道如何获取 JSON 格式的值吗? 这是
我有不同类型的数据(可能是字符串、整数......)。这是一个简单的例子: public static void main(String[] args) { before("one"); }
嗨,我是 json 和 javascript 的新手。 我在这个网站找到了使用json数据作为表格的方法。 我很好奇为什么当我尝试使用 json 数据作为表时,我得到 [Object,Object]
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我听别人说 null == object 比 object == null check 例如: void m1(Object obj ) { if(null == obj) // Is thi
Match 对象 提供了对正则表达式匹配的只读属性的访问。 说明 Match 对象只能通过 RegExp 对象的 Execute 方法来创建,该方法实际上返回了 Match 对象的集合。所有的
Class 对象 使用 Class 语句创建的对象。提供了对类的各种事件的访问。 说明 不允许显式地将一个变量声明为 Class 类型。在 VBScript 的上下文中,“类对象”一词指的是用
Folder 对象 提供对文件夹所有属性的访问。 说明 以下代码举例说明如何获得 Folder 对象并查看它的属性: Function ShowDateCreated(f
File 对象 提供对文件的所有属性的访问。 说明 以下代码举例说明如何获得一个 File 对象并查看它的属性: Function ShowDateCreated(fil
Drive 对象 提供对磁盘驱动器或网络共享的属性的访问。 说明 以下代码举例说明如何使用 Drive 对象访问驱动器的属性: Function ShowFreeSpac
FileSystemObject 对象 提供对计算机文件系统的访问。 说明 以下代码举例说明如何使用 FileSystemObject 对象返回一个 TextStream 对象,此对象可以被读
我是 javascript OOP 的新手,我认为这是一个相对基本的问题,但我无法通过搜索网络找到任何帮助。我是否遗漏了什么,或者我只是以错误的方式解决了这个问题? 这是我的示例代码: functio
我可以很容易地创造出很多不同的对象。例如像这样: var myObject = { myFunction: function () { return ""; } };
function Person(fname, lname) { this.fname = fname, this.lname = lname, this.getName = function()
任何人都可以向我解释为什么下面的代码给出 (object, Object) 吗? (console.log(dope) 给出了它应该的内容,但在 JSON.stringify 和 JSON.parse
我正在尝试完成散点图 exercise来自免费代码营。然而,我现在只自己学习了 d3 几个小时,在遵循 lynda.com 的教程后,我一直在尝试确定如何在工具提示中显示特定数据。 This code
我是一名优秀的程序员,十分优秀!