Javascript如何实现自动排序?

一个Metro风格的UI网页,如何实现鼠标拖拽某个图标以后其他图标根据被拖拽图标的位置自动排序?
注意:

  1. 图标大小可能不同;

  2. 要求结果得到保留(重载页面以后布局不变);

  3. 不需要考虑兼容性,只需简单讲讲大概思路。

效果就像 Windows10 的开始菜单:

查看回复