实现的效果就是页面内的图片可拖拽到任意位置,并将所在位置保存.下次打开页面依然可见.本文是作demo用,实际开发中,位置的数据应保存到数据库中.

好了,开始.

1.准备工作.

a.jquery(1.7.2),ui,cookie插件,json插件.一些图片(本文是5张).

2.页面.

上代码

1
2
3
4
5
6
7
<div class="img_list" id="img_list">
<div id="baidu"><img src="img/baidu.jpg" id="www.baidu.com"></div>
<div id="google"><img src="img/google.png" id="www.google.com"></div>
<div id="csdn"><img src="img/csdn.jpg" id="www.csdn.net"></div>
<div id="fly"><img src="img/fly.jpg" id="www.jfbcb.com"></div>
<div id="163"><img src="img/163.jpg" id="www.163.com"></div>
</div>

接下,先为每个img的父元素增加draggable,并且动态改变id,这样便于记录时减少工作量.当然,先得给它来2个事件,mouseenter,mouseleave.代码如下.

1
2
3
4
5
6
7
8
9
10
11
$("#img_list div").on({
mouseenter: function(){
            $(this).addClass('img_move');
            _t_id =$(this).attr('id');//保存原来id
            $('div.img_move').attr('id','img_move');   
                },
mouseleave: function(){  
             $('#img_move').removeClass('img_move').attr('id',_t_id);
            _t_id = '';//清空,临时保存id
        }
});

到目前为止,我们已实现动态加载id,下面重点来了,让div可拖拽.

只要在mouseenter事件中加上这句就行,这样当鼠标进入某块div时,div就变成可拖拽的了.

1
$( "#img_move").draggable();

3.拖拽后的保存.

如果,你刷新页面会发现,刚拖拽的图片,会恢复到初始位置.这个肯定不行,于是,保存就成了必须.实际开发一定要保存到数据库,因为,客户要是清空了cookie效果全部没有了...坑爹的360常干这事.

这里除了cookie还要用到json插件,这样保存的时候会方便并且把拖拽后元素的信息储备到同一个对象中,便于读取.

上代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
$( "#img_move").draggable({
     start:function(e,ui){
     ui.helper.css('z-index','999'); //拖动时元素一直是不被遮蔽
     },
     stop:function(e,ui){
        ui.helper.css('z-index','0'); //拖动结束,让元素可遮蔽
        var x  = ui.position.left ;
        var y  = ui.position.top;
        var id = _t_id;
        var temp = {'id':id,'x':x,'y':y};
          
        var _data = $.toJSON(temp);//转成json 
        $.cookie('img_list_'+_t_id,_data,{expires:1});  //保存信息,设置有效时间              
                 }
                 });

ps:元素在页面中的位置,简单的说是left,top的值决定的.

4.刷新后载入.

window.onload后把cookie保存的信息读出来,并赋到对应元素上.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
window.onload = function(){
    fix_img('baidu');
        fix_img('google');
        fix_img('csdn');
        fix_img('fly');
        fix_img('163');
    };
//fix_img
function fix_img(id){
  if(id){
      var _test_data = $.cookie('img_list_'+id);
      var _id = $.evalJSON(_test_data).id;
      var _x = $.evalJSON(_test_data).x;
      var _y = $.evalJSON(_test_data).y;       
          $('#'+_id).css('left',_x+'px').css('top',_y+'px');
    }
         
}

5.总结.

1.思路是先拖后保存.实现方式各有不同.

2.实际开发一定要保存到数据库.

3.参考了以下大大的文章.

http://www.zhangxinxu.com/wordpress/

ps:还一些,我记不得,如果是你,让我知道,加你的文章出处.

jquery 实现页面拖拽并保存到cookie的更多相关文章

  1. jQuery切换网页皮肤保存到Cookie实例

    效果体验:http://keleyi.com/keleyi/phtml/jqtexiao/25.htm 以下是源代码: <!DOCTYPE html PUBLIC "-//W3C//D ...

  2. jQuery切换网页皮肤并保存到Cookie示例代码

    经过使用,靠谱! <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...

  3. 监听页面中的某个div的滚动事件,并将其滚动距离保存到cookie

    在html中,写一个id为type的div: <div class="type" id="type"></div> css: .type ...

  4. 个人学习记录1:二维数组保存到cookie后再读取

    二维数组保存到cookie后再读取 var heartsArray = [[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],[0,0,0,0,0,0,0,0,0,0,0],[0,0, ...

  5. 将用户信息保存到Cookie中

    /** * 把用户保存到Cookie * * @param request * @param response * @param member */ private void rememberPwdA ...

  6. jQuery网页元素拖拽插件

    效果说明:配合已有CSS样式,载入插件后,网页元素可以随意在窗口内拖拽,设置了原位置半透明和拖拽半透明的效果选项,可根据需要选择.另外,当页面上有多个可拖拽元素时,可以载入另外一个用于设置z-inde ...

  7. Jquery.Sorttable 桌面拖拽自定义

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  8. JQuery UI的拖拽功能

    JQuery UI是JQuery官方支持的WebUI 代码库,包含底层交互.动画.特效等API,并且封装了一些Web小部件(Widget).同时,JQuery UI继承了jquery的插件支持,有大量 ...

  9. JQuery UI的拖拽功能实现方法小结

    JQuery UI提供的API极大简化了拖拽功能的开发.只需要分别在拖拽源(source)和目标(target)上调用draggable和droppable两个函数即可. 拖拽原理 首先要明确几个概念 ...

随机推荐

  1. winform C#屏幕右下角弹出消息框并自动消失

    ①弹出信息框后慢慢下降消失 在主窗体中新增按钮重命名为btnShowAndDisappearMessages,在click事件中写如下代码: private void btnShowAndDisapp ...

  2. C# Delegate 异步调用

    namespace ConsoleApplication22 { /// /// 异步操作 /// /// /// /// //internal Func<int,int,int> int ...

  3. mws文件中的tab文件改为相对路径

    用mapinfo将现有的多个图层(tab)文件保存成一个mws工作空间后,将此mws文件发到另一台电脑上后,打开mws,提示无法打开各个tab文件,文件不存在,显示的路径是当时原电脑添加时的绝对路径. ...

  4. yii2源码学习笔记(十五)

    这几天有点忙今天好些了,继续上次的module来吧 /** * Returns the directory that contains the controller classes according ...

  5. 我学C的那些年[ch02]:宏,结构体,typedef

    c语言的编译过程: 预处理 编译 汇编 链接 而预处理中有三种情况: 文件包含( #include ) 条件编译(#if,#ifndef,#endif) 宏定义( #define ) 宏就是预处理中的 ...

  6. Swift 类和结构体的简单认识

    类和结构体的共同点: 定义属性用于存储值 定义方法用于提供功能 定义附属脚本用于访问值 通过拓展增加默认实现的功能 定义构造器用于生成初始化值 实现协议以提供某种标准功能 类是引用类型 结构体是值类型 ...

  7. bzoj 2733: [HNOI2012]永无乡 离线+主席树

    2733: [HNOI2012]永无乡 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1167  Solved: 607[Submit][Status ...

  8. HDU 2993 MAX Average Problem dp斜率优化

    MAX Average Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Othe ...

  9. scroller

    sh做的js控件. 另外内部被scroller包裹的div不可以定位成absolute,会撑不出高度. 上面只是使用的注意事项. 很佩服人家能封装出这样的控件. 如果我也能写得出来就能毕业了,也不用担 ...

  10. quartz源码解析--转

    quartz源码解析(一)  . http://ssuupv.blog.163.com/blog//146156722013829111028966/ 任何个人.任何企业.任何行业都会有作业调度的需求 ...