用户定制应用顺序

经常会有这样的个性化需求,用户希望可以在页面上按自己的偏好拖放移动应用图标,而且还能保存,下次访问该页面时应用图标就是按自己上次保存的顺序展示的。

拖放是一种常见的特性,即抓取对象后移动到另一个位置后放下。在 HTML5 中,拖放是标准的一部分,任何元素只要将draggable属性设置为"true"就能够拖放。

前端JS从后端获取到可显示应用列表和用户定制的应用显示顺序,在例程中直接写在json变量里了。用户对图标进行一顿拖放后,点击"显示app顺序"按钮,页面弹窗显示当前app顺序,JS可以把app顺序传到后端,更新用户定制的app顺序,这样可以满足用户对图标显示顺序的个性化要求。

html 复制代码
<!DOCTYPE html>
<html>
<button name="showorder" id="showorder" style="float: right;">当前app顺序</button>
<ul id="applist">
</ul>
<script src="jquery-3.6.1.min.js"></script>
<script>

var srcdiv = null;

var applist=[
{"appid":"app1","appdesc":"百度","appurl":"https://www.baidu.com","applogo":"https://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png"},
{"appid":"app2","appdesc":"CSDN","appurl":"https://www.csdn.net","applogo":"https://img-home.csdnimg.cn/images/20201124032511.png"},
{"appid":"app3","appdesc":"中国日报网","appurl":"https://www.chinadaily.com.cn/","applogo":"https://www.chinadaily.com.cn/image_e/2016/logo.jpg"}
];

var apporder=["app3","app2","app1"];

//$.get(url,(obj)=>{applist=obj.applist,apporder=obj.apporder},"json")

function allowDrop(ev) { ev.preventDefault(); }

function drag(ev,divdom) { srcdiv=divdom; }

function drop(ev,divdom) { 
	ev.preventDefault();
	if (srcdiv != divdom) { document.getElementById("applist").insertBefore(srcdiv, divdom); }
}

$(document).ready(()=>{
	apporder.forEach(itm=>{
		let item=applist.find(app=>(app.appid==itm));
		$("#applist").append(`<li οndrοp="drop(event,this)" οndragοver="allowDrop(event)" draggable="true" οndragstart="drag(event, this)"><div id="${item.appid}" ><a href="${item.appurl}" target="_blank"><img src="${item.applogo}"><p>${item.appdesc}</p></a></div></li>`)
		})

	$("#showorder").click(()=>{ 
		let appids=[];
		$("#applist li div").each(function(index) { appids.push($(this).attr("id")); });
		alert(appids)
		//$.post(url,{"neworder":appids})
		})

})

</script>
</html>
相关推荐
Mintopia6 分钟前
🤖 微服务架构下 WebAI 服务的高可用技术设计
前端·javascript·aigc
江城开朗的豌豆21 分钟前
React 跨级组件通信:避开 Context 的那些坑,我还有更好的选择!
前端·javascript·react.js
吃饺子不吃馅1 小时前
root.render(<App />)之后 React 干了哪些事?
前端·javascript·面试
鹏多多1 小时前
基于Vue3+TS的自定义指令开发与业务场景应用
前端·javascript·vue.js
江城开朗的豌豆1 小时前
Redux 与 MobX:我的状态管理选择心路
前端·javascript·react.js
Cosolar1 小时前
前端如何实现VAD说话检测?
前端
CodeSheep2 小时前
当了leader才发现,大厂最想裁掉的,不是上班总迟到的,也不是下班搞失联的,而是经常把这3句话挂在嘴边的
前端·后端·程序员
吃饺子不吃馅2 小时前
✨ 你知道吗?SVG 里藏了一个「任意门」——它就是 foreignObject! 🚪💫
前端·javascript·面试
IT_陈寒2 小时前
Python开发者必须掌握的12个高效数据处理技巧,用过都说香!
前端·人工智能·后端
gnip10 小时前
企业级配置式表单组件封装
前端·javascript·vue.js