这里,您将获得使用jQuery的JSP的AJAX示例。
AJAX用于从服务器发送和接收数据,而无需重新加载页面。我们可以使用jQuery轻松实现AJAX。它为AJAX功能提供了各种方法。
我使用Eclipse IDE创建了这个示例。下面我分享了详细的步骤。
1.首先通过转到文件>新建>动态Web项目来创建动态Web项目。
2.现在给出任何名称,然后单击Finish以创建项目。
3.要在我们的代码中使用jQuery,我们需要下载jQuery库。转到下面的链接并下载jQuery库的开发版本。
下载链接: https ://jquery.com/download/
4.复制并粘贴到项目的WebContent文件夹中。见下面的截图。
5. 在WebContent文件夹中创建两个文件index.jsp和content.jsp。在相应的文件中复制并粘贴以下代码。
index.jsp
<html> <head> <title>AJAX With JSP Using jQuery</title> <script src="jquery-1.11.3.js"></script> <script> $(document).ready(function(){ $("#btn").click(function(){ $.get("content.jsp",function(data){ $("h2").html(data); }); }); }); </script> </head> <body> <h2></h2> <input type="button" id="btn" value="Show"/> </body> </html>
content.jsp
<%out.print("This is AJAX with JSP using jQuery");%>
6.最后在服务器上运行您的项目。
产量
说明
jQuery代码写在head部分中。对于使用jQuery库,我们必须将它包含在我们的页面上。我通过在<script src=“”> </ script>标记中提供库的源代码来完成此操作。
当我们单击Show按钮时,get()函数处理AJAX GET请求并从服务器获取数据。它的第一个参数是从中获取数据的页面的url。在第二个参数中,调用另一个函数,从服务器获取的信息存储在数据中。最后,我们使用html()函数在h2标签中编写数据。
如果您遇到任何问题,请在下方评论。
快乐编码!!
者 | 水车
链接 | www.cnblogs.com/xuange306
前言
以前的项目大多数都是Java程序猿又当爹又当妈,既搞前,又搞后端。
随着时代的发展,渐渐的许多大中小公司开始把前后端的界限分的越来越明确,前端工程师只负责前端的事情,后端工程师只管后端的事情。正所谓术业有专攻,一个人如果什么都会,那么每一样都很难达到精通。
大中型公司需要专业人才,小公司需要全才,但是对于个人职业发展来说,我建议是分开。你要是这辈子就吃 Java 这碗饭,就不要去研究什么 css,js 等等。
把你的精力专注在 Java,JVM 原理,Spring原理,mysql锁,事务,多线程,大并发,分布式架构,微服务,以及相关的项目管理等等,这样你的核心竞争力才会越来越高,正所谓你往生活中投入什么,生活就会反馈给你什么。
曾几何时
我们的Java Web项目都是使用了若干后台框架进行开发,Spring、Spring MVC、MyBatis、Hibernate等等。
而且大多数项目在Java后端都是分了三层,控制层、业务层、持久层。控制层负责接收参数,调用相关业务层,封装数据,以及路由到JSP页面。然后Jsp页面上使用各种标签(jstl/el)表达式将后台的数据展现出来。
我们先看上述这种情况,需求定完了,代码写完了,测试测完了,然后发布:
你需要用maven或者eclipse等工具把你的代码打成一个war包,然后把这个war包发布到你的生产环境下的Web容器里,发布完了之后,你要启动你的Web容器,开始提供服务,这时候你通过配置域名,dns等等相关,你的网站就可以访问了。
那我们来看,你的前后端代码是不是全都在那个war包里?包括你的js,css,图片,各种第三方的库,对吧?
好,下面在浏览器中输入你的网站域名:www.xxx.com,之后发生了什么?
浏览器在通过ip路由到你的服务,在tcp3次握手之后,通过tcp协议开始访问你的Web服务器,你的Web服务器得到请求后,开始提供服务,接收请求,之后通过response返回你的应答给浏览器。
我们先假设你的首页中有100张图片,以及一个单表的查询,此时,用户的看似一次http请求,其实并不是一次,用户在第一次访问的时候,浏览器中不会有缓存,你的100张图片,浏览器要连着请求100次http请求(有人会跟我说http长链短链的问题,不在这里讨论),你的Web服务器接收这些请求,都需要耗费内存去创建socket来玩tcp传输。
重点来了,这样的话,你的Web服务器的压力会非常大,因为页面中的所有请求都是只请求到你这台服务器上,如果1个人还好,如果10000个人并发访问呢(先不聊web服务器集群,这里就说是单实例Web服务器),那你的服务器能扛住多少个tcp链接?你的服务器的内存有多大?你能抗住多少IO?你给web服务器分的内存有多大?会不会宕机?
这就是为什么,越是大中型的Web应用,他们越是要解耦。
理论上你可以把你的数据库+应用服务+消息队列+缓存+用户上传的文件+日志+等等都扔在一台主机上,但是这样就好像是你把鸡蛋都放在一个篮子里,隐患非常大。
正常的分布式架构,是都要拆开的,你的应用服务器集群(前,后)+文件服务器集群+数据库服务器集群+消息队列集群+缓存集群等等。
步入正题
下面步入正题,首先以后的 Java web项目都尽量要避免使用JSP,要搞前后台解耦,玩分布式架构,这样我们的应用架构才更强。
使用 JSP 的痛点:
1. 动态资源和静态资源全部耦合在一起,无法做到真正的动静分离。服务器压力大,因为服务器会收到各种http请求,例如css的http请求、js的、图片的、动态代码的等等。一旦服务器出现状况,前后台一起玩完,用户体验极差。
2. 前端工程师做好html后,需要由Java工程师来将html修改成jsp页面,出错率较高(因为页面中经常会出现大量的js代码),修改问题时需要双方协同开发,效率低下。
3. JSP 必须要在支持Sava的Web服务器里运行(例如tomcat等),无法使用nginx等(nginx据说单实例http并发高达5w,这个优势要用上),性能提不上来。
4. 第一次请JSP,必须要在web服务器中编译成servlet,第一次运行会较慢。
5. 每次请求JSP都是访问Servlet再用输出流输出的html页面,效率没有直接使用html高。
6. JSP 内有较多标签和表达式,前端工程师在修改页面时会捉襟见肘,遇到很多痛点。
7. 如果JSP中的内容很多,页面响应会很慢,因为是同步加载。
基于上述的一些痛点,我们应该把整个项目的开发权重往前移,实现前后端真正的解耦!
老的方式:
1. 客户端请求
2. 服务端的servlet或controller接收请求(路由规则由后端制定,整个项目开发的权重大部分在后端)
3. 调用service,dao代码完成业务逻辑
4. 返回JSP
5. jsp展现一些动态的代码
新的方式:
1. 浏览器发送请求
2. 直接到达html页面(路由规则由前端制定,整个项目开发的权重前移)
3. html页面负责调用服务端接口产生数据(通过ajax等等)
4. 填充html,展现动态效果。
有兴趣的童鞋可以访问一下阿里巴巴等大型网站,然后按一下F12,监控一下你刷新一次页面,他的http是怎么玩的,大多数都是单独请求后台数据,使用 json传输数据,而不是一个大而全的http请求把整个页面包括动+静全部返回过来
这样做的好处是:
1. 可以实现真正的前后端解耦,前端服务器使用nginx。
前端服务器放的是css,js,图片等等一系列静态资源。甚至你还可以css,js,图片等资源放到特定的文件服务器,例如阿里云的oss,并使用cdn加速,前端服务器负责控制页面引用,跳转,调用后端的接口,后端服务器使用tomcat。
这里需要使用一些前端工程化的框架比如nodejs,react,router,react,redux,webpack
2. 发现bug,可以快速定位是谁的问题,不会出现互相踢皮球的现象。
页面逻辑,跳转错误,浏览器兼容性问题,脚本错误,页面样式等问题,全部由前端工程师来负责。
接口数据出错,数据没有提交成功,应答超时等问题,全部由后端工程师来解决。
双方互不干扰,前端与后端是相亲相爱的一家人。
3. 在大并发情况下,我可以同时水平扩展前后端服务器,比如淘宝的一个首页就需要2000台前端服务器做集群来抗住日均多少亿+的日均pv。
去参加阿里的技术峰会,听他们说他们的web容器都是自己写的,就算他单实例抗10万http并发,2000台是2亿http并发,并且他们还可以根据预知洪峰来无限拓展,很恐怖,就一个首页。
4. 减少后端服务器的并发压力,除了接口以外的其他所有http请求全部转移到前端nginx上。
5. 即使后端服务暂时超时或者宕机了,前端页面也会正常访问,只不过数据刷不出来而已。
6. 也许你也需要有微信相关的轻应用,那样你的接口完全可以共用,如果也有app相关的服务,那么只要通过一些代码重构,也可以大量复用接口,提升效率。
7. 页面显示的东西再多也不怕,因为是异步加载。
注意:
1. 在开需求会议的时候,前后端工程师必须全部参加,并且需要制定好接口文档,后端工程师要写好测试用例,不要让前端工程师充当你的组专职测试,推荐使用
chrome的插件postman,service层的测试用例拿junit写。
2. 上述的接口并不是java里的interface,说白了调用接口就是调用你controler里的方法。
3. 加重了前端团队的工作量,减轻了后端团队的工作量,提高了性能和可扩展性。
4. 我们需要一些前端的框架来解决类似于页面嵌套,分页,页面跳转控制等功能。(上面提到的那些前端框架)。
5. 如果你的项目很小,或者是一个单纯的内网项目,那你大可放心,不用任何架构而言,但是如果你的项目是外网项目,呵呵哒。
6. 以前还有人在使用类似于velocity/freemarker等模板框架来生成静态页面,现在这种做法也被淘汰掉了。
7. 这篇文章主要的目的是说JSP在大型外网Java web项目中被淘汰掉,可没说JSP可以完全不学,对于一些学生朋友来说,servlet等相关的Java web基础还是要掌握牢的,不然你以为Spring MVC这种框架是基于什么来写的?
一个舒服的环境走到一个不舒服的环境需要一个过程。当然这种不舒服的学习区不仅仅局限于工作,还有生活上,还需要去适应你的生活——不过,我想应该很快就能适应了。
如何从菜鸟成长为高效程序员?要想成为一个高效的程序员,不是一朝一夕的事,而是贵在坚持,程序员的工作都是在不断淘汰旧的东西,接受新的,我们必须学会去积累工作经验和成果。所谓高效程序员,就是逻辑思维敏捷,学习能力强悍,敲代码速度绝对是要快,代码规范严谨,善于总结经验,视野开阔,不局限于某一门专属编程语言,能够举一反三。
筑基阶段:
1.敲代码速度要快,要求手指灵活,尽量减少输入出错。这个是基本功,不然何以达到一定的代码量。
2.精通几个常用的代码编辑工具。(注意,这里说的是编辑工具,除了常用的eclipse,myeclipse,jBuilder等IDE工具外,还必须掌握文本编辑工具,如notepad++,vim)。
3.掌握Linux系统中常规命令。(这个是所有程序员都必须掌握的基本功)。
4.随时随地的做笔记。(这个就不解释了,反正善于总结经验不会错了,可以推荐使用有道笔记)。
5.学会一些主流的代码管理工具的使用。(如SVN,gitHub,maven等)
初级阶段
6.熟悉并精通某种编程语言的基础和特性。(java语言必须掌握corejava基础部分)
7.善于给自己写一些工具,拿来即用的那种。(如数据库连接,文件读写操作等等)
8.掌握web开发的常用技术。(如HTML,CSS,javascript,Ajax,JSP,jQuery)
9.掌握常用数据库的基本操作。(如oracle,mysql)
中级阶段
10.掌握一些主流开源框架,设计思想。(如,spring MVC ,Struts2+hibernate+spring/SSH ,EJB等)
11.掌握设计模式,学会使用一些开发模式。
12.掌握Linux中的shell编程
13.学会使用数据库的DDL,DML,以及存储过程。
14.熟悉项目的整个生命周期,从需求到上线中的各个阶段。
15.关注技术网站和社区,开拓思路,汲取他人的优序经验,同时分享自己经验。(如csdn ,oschina等)
16.熟悉整个项目周期的中的各类文档。
17.定期给自己策划一个项目,练手。
高级阶段
18.关注科技,了解IT界动态,学会发现和创新。
19.开始学习项目管理相关知识,学会如何成为一个优秀的项目管理人。
20.适时给自己买一些书籍,给自己大脑及时充电。
21.经常参加一些培训讲座,开拓视野。
22.关注政策,了解时代互联网发展趋势,学习和创新。
还有就是当你觉得最近的生活很无聊时,一定是你进入了舒适区:
新买的钟很漂亮,上面写的是“Give Me 5”:
不是“凌晨五点的深圳”的意思:
我也是每天12点前睡,然后七点多起床的——三遍
足够的睡眠,才能更好的前进。
足够的睡眠,才能更好的前进。
足够的睡眠,才能更好的前进。
其实IT界已然成了一大江湖,IT江湖门派之多,编程流派何其多,可能每个人踏足IT江湖都身怀绝技吧,上面的22条也许不一定适合你,但是我还是希望它能帮助大家,大家共同努力。
*请认真填写需求信息,我们会在24小时内与您取得联系。