最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

关于Popup弹出框添加数据实现方法

来源:动视网 责编:小OO 时间:2020-11-27 20:07:58
文档

关于Popup弹出框添加数据实现方法

逻辑;窗口P1中显示一组数据,并提供一个添加按钮。点击按钮,弹出新的浏览器窗口P2,在其中添加一条数据并提交后,窗口P2自动关闭。新添加数据动态添加到窗口P1中并被选中。所需知识:JS BOM 窗口对象;JS自执行函数。实现;下面在Django中简单实现下,因为比较简单,路由和视图就写在一起了。1.路由和视图部分;2.访问视图p1,返回页面p1.html。
推荐度:
导读逻辑;窗口P1中显示一组数据,并提供一个添加按钮。点击按钮,弹出新的浏览器窗口P2,在其中添加一条数据并提交后,窗口P2自动关闭。新添加数据动态添加到窗口P1中并被选中。所需知识:JS BOM 窗口对象;JS自执行函数。实现;下面在Django中简单实现下,因为比较简单,路由和视图就写在一起了。1.路由和视图部分;2.访问视图p1,返回页面p1.html。
本文主要为大家详细介绍了Popup弹出框添加数据的简单实现方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

逻辑

窗口P1中显示一组数据,并提供一个添加按钮
点击按钮,弹出新的浏览器窗口P2,在其中添加一条数据并提交后,窗口P2自动关闭
新添加数据动态添加到窗口P1中并被选中
所需知识:JS BOM 窗口对象;JS自执行函数

实现

下面在Django中简单实现下,因为比较简单,路由和视图就写在一起了。

1.路由和视图部分

2.访问视图p1,返回页面p1.html:

<head>
 <meta charset="UTF-8">
 <title>p1页面</title>
</head>

<body>
<h2>p1页面</h2>

<select id="cityChoose">
 <option>上海</option>
 <option>北京</option>
</select>
<input type="button" value="添加" onclick="popupFunc();"/>

<script>
 popupFunc = function () {
 window.open('/p2.html/', 'p2', "status=1, height:300, width:300, toolbar=0, resizeable=1")
 //open(url, name, 窗口参数),注意name不能重名
 };

 callback = function (city) {
 var opt = document.createElement('option');
 opt.innerText = city;
 opt.setAttribute('selected', 'selected');
 var selEle = document.getElementById('cityChoose');
 selEle.appendChild(opt);
 }
</script>
</body>

说明:

1、点击添加按钮,执行popupFunc:访问'/p2.html/',并在新窗口中打开页面p2.html
2、定义回调函数callback:它接收一个参数city,将其动态添加到下拉选项中并设置为选中状态。

3.弹出窗口中显示p2.html如下:

<head>
 <meta charset="UTF-8">
 <title>p2页面</title>
</head>
<body>
<h2>p2页面</h2>

<form method="post">
 {% csrf_token %}
 <input type="text" name="city">
 <input type="submit" value="提交">
</form>
</body>

说明:这里没有指定form表单的action=url参数,用户输入数据后,默认提交到当前地址,即'/p2.html/',提交到视图p2

4.视图p2收到提交的数据后,传入模板并返回页面popup.html:

<head>
 <meta charset="UTF-8">
 <title>正在返回</title>
</head>
<body>
<script>

 (function (city) {
 window.opener.callback(city);
 window.close();
 })("{{ city }}")

</script>
</body>

说明:

  • 这里定义了JS自执行函数:它调用打开弹出窗口的窗口中的回调函数(即P1中的callback),并把用户输入数据作为参数传入;关闭自身。

  • 如果p2视图返回错误信息,也可以在popup.html中作显示(略)。

  • 自执行函数可以参考 JavaScript 自执行函数和 jQuery扩展方法

  • 效果图:

    文档

    关于Popup弹出框添加数据实现方法

    逻辑;窗口P1中显示一组数据,并提供一个添加按钮。点击按钮,弹出新的浏览器窗口P2,在其中添加一条数据并提交后,窗口P2自动关闭。新添加数据动态添加到窗口P1中并被选中。所需知识:JS BOM 窗口对象;JS自执行函数。实现;下面在Django中简单实现下,因为比较简单,路由和视图就写在一起了。1.路由和视图部分;2.访问视图p1,返回页面p1.html。
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top