Django中使用jquery实现ajax方式动态局部加载页面

在尝试开发Django项目的过程中,想使用ajax实现点击导航栏后局部加载页面的功能。

尝试搜到的方法,比如使用.get或.load函数,发现其都会向Django服务器发送静态资源的请求,但Django服务器无法直接返回静态资源,导致请求失败。

因此突发奇想,觉得能不能直接利用下载文件的方式,将静态资源直接从Django服务器上传输过来,并进行动态加载。

这是前端测试代码

<li class="menu">
	<a href="/load/?flag=function1">功能1</a>
</li>
...
<script src="/static/js/jquery-3.4.1.min.js"></script>
<script>
	$(() => {
		$('.menu>a').on('click', (evt) => {
			evt.preventDefault()
			let url = $(evt.target).attr('href')
			$('.main').load(url)
		})
	})
</script>

这是urls.py代码

urlpatterns = [
    path('load/', views.load),
]

这是views.py代码

def load(request):
    nowdir = os.getcwd()
    try:
        flag = str(request.GET.get('flag'))
        path = nowdir + "/templates"
        os.chdir(path)
        filename = flag + ".html"
        f = open(file=filename, mode="rb")
        data = f.read()
        resp = HttpResponse(data, content_type='application/vnd.ms-excel')
        # 通过响应头告知浏览器下载该文件以及对应的文件名
        resp['content-disposition'] = f'attachment; filename*=utf-8\'\'{filename}'
        return resp
    except Exception:
        data = {'code': 30001, 'msg': '加载模板失败'}
        return JsonResponse(data)
    finally:
        os.chdir(nowdir)

经尝试后发现,此方法可以实现ajax方式局部加载页面。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值