使用sortable这个强力插件就很容易实现拖拽功能,它是目前比较牛逼的拖拽插件,无需jquery,就可以全面支持pc和移动,参考以下github文档就有很详细的说明,也给了很多
demo,插件就用我给你的那个就可以,不用额外添加其他库
GitHub:https://github.com/RubaXa/Sortable

以下的simple demo是我自己写的,就这么几行简单代码就完事了
simple demo:
html code:

<input type="hidden" value="" name="template_ending_order" id="template_ending_order">
<ul class="list-group" id="sort-ending-list">
    <li class="list-group-item" draggable="false">致谢</li>
    <li class="list-group-item" draggable="false">结论</li>
    <li class="list-group-item">参考文献</li>
</ul>
<submit id="form-save">保存</submit)

js code:
  $(document).ready(function(){
  var ulElement = document.getElementById('sort-ending-list');
  if (ulElement != null) {
    var sortable = Sortable.create(ulElement, {
      ghostClass: "sort-ghost"
    });
  }
 $("#form-save").submit(function() {
   setEndingOrder("#template_ending_order")
});
});
通过这个函数,将你的拖动结果拼接成一个字符串,比如:"结论;参考文献;致谢",你这个地方可以选择id作为拼接结果,比如“1;2;3”
function setEndingOrder(endingOrderId){
  var ulElement = document.getElementById('sort-ending-list');
  var liElements = ulElement.children;
  var value = "";
  for (var i=0; i<liElements.length; ++i) {
    if (i < liElements.length -1)
      value += liElements[i].innerHTML + ';';
    else
      value += liElements[i].innerHTML;
  }
  var inputElement = document.getElementById(endingOrderId);
  inputElement.value = value;
}
class Template < ActiveRecord::Base

  ENDING_PARTS =
    [
      Setting.templates.ending_order_conclusion,
      Setting.templates.ending_order_reference,
      Setting.templates.ending_order_resume
    ]

  validates :chapter_count,     :presence => true, :inclusion => { :in => 1..9 }
  validates :conclusion,        :presence => true, :inclusion => { :in => [0,1] }
  validates :achievement,       :presence => true, :inclusion => { :in => [0,1] }
  validates :introduction,      :presence => true, :inclusion => { :in => [0,1] }

  # Conditional Validation not Working
  validates :ending_order,      :presence => true, :if => :valid_ending_order?

  def valid_ending_order?
    cur_parts = self.ending_order.split(';')
    cur_parts.each do |part|
      if ENDING_PARTS.include?(part) == false
        return false;
      end
    end
    return true;
  end
end
 def update
    @thesis = Thesis.find(params[:thesis_id])
    @template = @thesis.templateif @template.update(template_params)
      。。。。。。
      else
        render :edit
      end
    else
      render :edit
    end
  end

  private
    def template_params
      params.require(:template).permit(: :resume, :ending_order, :introduction)
    end

    def structure_params
      params.require(:template).permit(:structure_id)
    end

sortable实现拖拽功能的更多相关文章

  1. vuejs2.0使用Sortable.js实现的拖拽功能

    简介 在使用vue1.x之前的版本的时候,页面中的拖拽功能,我在项目中是直接用的jquery ui中的sortable.js,只是在拖拽完成后,在update的回调函数中又重新排序了存放数据的数组.但 ...

  2. vue2.0使用Sortable.js实现的拖拽功能

    简介 在使用vue1.x之前的版本的时候,页面中的拖拽功能,我在项目中是直接用的jQuery ui中的sortable.js,只是在拖拽完成后,在update的回调函数中又重新排序了存放数据的数组.但 ...

  3. vuejs2.0使用Sortable.js实现的拖拽功能( 转)

    文章目录   简介 实现效果 html主要代码 css代码 js代码 简介 在使用vue1.x之前的版本的时候,页面中的拖拽功能,我在项目中是直接用的jquery ui中的sortable.js,只是 ...

  4. React Editor 应用编辑器(1) - 拖拽功能剖析

    这是可视化编辑器 Gaea-Editor 的第一篇连载分析文章,希望我能在有限的篇幅讲清楚制作这个网页编辑器的动机,以及可能带来的美好使用前景(画大饼).它会具有如下几个特征: 运行在网页 文档流布局 ...

  5. JQuery UI的拖拽功能

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

  6. html5 Sortable.js 拖拽排序源码分析

    最近公司项目经常用到一个拖拽 Sortable.js插件,所以有空的时候看了 Sortable.js 源码,总共1300多行这样,写的挺完美的.   本帖属于原创,转载请出名出处. 官网http:// ...

  7. el-transfer增加拖拽功能

    el-transfer增加拖拽排序,左右互相拖拽功能: npm i sortablejs <template> <el-transfer ref="transfer&quo ...

  8. RCP:拖拽功能的实现 Drag and Drop

    SWT中的拖拽是使用的org.eclipse.swt.dnd. 有三个需要密切注意的类: 1.DragSource 2.DropTarget 3.Transfer DragSource封装了需要被拖拽 ...

  9. js实现登陆页面的拖拽功能

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>登 ...

随机推荐

  1. confirg

     如果用户点击确定按钮,则 confirm() 返回 true.如果点击取消按钮,则 confirm() 返回 false.在用户点击确定按钮或取消按钮把对话框关闭之前,它将阻止用户对浏览器的所有输入 ...

  2. 嵌入式开发之davinci--- spi 中的时钟极性CPOL和相位CPHA

    PI的极性Polarity和相位Phase,最常见的写法是CPOL和CPHA,不过也有一些其他写法,简单总结如下:(1) CKPOL (Clock Polarity) = CPOL = POL = P ...

  3. smartJS 0.1 API 讲解 - Trigger

    上篇介绍了PromiseEvent,本篇介绍Trigger - 基于Promise的aop的体现:(感觉自己的对这些命名一直都很挫,也懒得想了,所以就凑合的用) Trigger 在目标对象上加入触发器 ...

  4. ReSharper 配置及用法(ZHUANG)

    1:安装后,Resharper会用他自己的英文智能提示,替换掉 vs2010的智能提示,所以我们要换回到vs2010的智能提示 2:快捷键.是使用vs2010的快捷键还是使用 Resharper的快捷 ...

  5. 显示所有APP的进程详细信息(进程ID、进程所在UID、进程占用内存、进程名)

    main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:and ...

  6. Jmeter - 分布式部署负载机

    1. 原理图: 2.具体操作 ① 负载机 安装JDK.Jmeter[版本与Controller 调度机一致] ② 配置环境变量 ③ 负载机自定义端口号 a.进入Jmeter的bin目录,找到Jmete ...

  7. cascade(级联)和inverse关系详解

    序言 写这篇文章之前,自己也查了很多的资料来搞清楚这两者的关系和各自所做的事情,但是百度一搜,大多数博文感觉说的云里雾里,可能博主自己清楚是怎么一回事,但是给一个不懂的人或者一知半解的人看的话,别人也 ...

  8. 解决phantomjs输出中文乱码

    解决phantomjs输出中文乱码,可以在js文件里添加如下语句: phantom.outputEncoding="gb2312"; // 解决输出乱码

  9. python3连接外部Mysql

    前提条件,已经安装过MySQL(比如说以前web开发安装过MySQL) 1.安装PyMySQL pip install PyMySQL 2.测试 import pymysql as ps db = p ...

  10. devmapper: Thin Pool has 162394 free data blocks which is less than minimum required 163840 free data blocks

    问题: 制作镜像的时候报错 devmapper: Thin Pool has 162394 free data blocks which is less than minimum required 1 ...