点击打开弹框展示数据_Popup弹出框添加数据实现方法

本文实例为大家分享了Popup弹出框添加数据的具体代码,供大家参考,具体内容如下

逻辑

窗口P1中显示一组数据,并提供一个添加按钮

点击按钮,弹出新的浏览器窗口P2,在其中添加一条数据并提交后,窗口P2自动关闭

新添加数据动态添加到窗口P1中并被选中

所需知识:JS BOM 窗口对象;JS自执行函数

实现

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

1.路由和视图部分

from django.conf.urls import url

from django.shortcuts import render

def p1(request):

return render(request, 'p1.html')

def p2(request):

if request.method == 'GET':

return render(request, 'p2.html')

elif request.method == 'POST':

city = request.POST.get('city')

print('执行数据保存操作...')

return render(request, 'popup.html',{'city':city})

urlpatterns = [

url(r'^p1.html/', p1),

url(r'^p2.html/', p2),

]

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

p1页面

p1页面

上海

北京

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);

}

说明:

1、点击添加按钮,执行popupFunc:访问'/p2.html/',并在新窗口中打开页面p2.html

2、定义回调函数callback:它接收一个参数city,将其动态添加到下拉选项中并设置为选中状态。

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

p2页面

p2页面

{% csrf_token %}

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

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

正在返回

(function (city) {

window.opener.callback(city);

window.close();

})("{{ city }}")

说明:

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

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

效果图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值