当前位置:首页 > 芯闻号 > 充电吧
[导读]事件驱动的Web之旅——JSP与JavaScript的融合 (此文献给所有使用Delphi的程序员) 说正题之前,我先写个序吧! 我深爱着Delphi,不能自拔。可是我也看到了B/S是以后程序设计的大

事件驱动的Web之旅——JSP与JavaScript的融合

(此文献给所有使用Delphi的程序员)

说正题之前,我先写个序吧!

我深爱着Delphi,不能自拔。可是我也看到了B/S是以后程序设计的大方向,多年更随Delphi,使我在这个时候选择Java/JSP(你知道吗?第一个尝试跨平台开发的语言是Pascal)。说句实话,在Windows的桌面开发领域Delphi当之无愧为老大。他是那么的快捷和方便,在学习Web的时候,我也带进了Delphi的思想,为什么Web不可以像Windows Application那样方面呢?基于事件驱动的,状态自动保持的(这其实是Windows的思想)。然而,学了Web开发才知道,当你要做一些让服务器知道得页面变动时,你就必须提交,提交可以改变页面的状态。当然,这也增加了保持页面状态的复杂性。不过不要紧,我们慢慢来。

 

JSP与JavaScript的融合

说句极端的话,对于用户来说,JSP和JavaScript的效果是一样的?也许现在就开始有人扔鸡蛋了。不过你想想,怎样才能开发出理想的适合于用户使用的Application呢?这当然是站在用户的角度。如果站在程序员的角度,我刚才的话会招来很多人嘲笑,但是对于用户来说,他们不管你有多少代码,不管你有什么样的数据库支持,不管你用的是起泡排序还是快速排序,他们关心的只是面子上的问题。本文也不是讨论美工设计的。我这时要让JSP和JavaScript达到相同的效果,不过这是对于用户来说的。

也曾在CSDN的论坛上看到JSP的变量能不能被JavaScript调用,JavaScript可不可以控制JSP的问题,答案通常是两种:第一种便是直截了当的回答“不能,这根本是两码事”、第二种无非是比较诚恳“这一个是服务端、一个是客户端,怎么可能,看看书吧”。其实,殊不知,这是一个非常值得探讨的问题。

不过先别扯远了,我们先看看在用户的角度,JSP和JavaScript相同的效果。

 

程序一:一个方向控制程序,浏览器里有五个按钮,上下左右中。点击上面的按钮中间的按钮向上移动,点击下面的按钮中间的按钮向下移动……以此类推,点击中间的按钮恢复初始状态。

先来看一看JSP代码:

FiveButtons.jsp

<%@ page contentType="text/html; charset=utf-8" language="java" %> <%@ page import="java.sql.*"%>

<%

    int iLeft;

    int iTop;

    if (request.getParameter("hidL") != null) {

        iLeft = Integer.parseInt(request.getParameter("hidL"));

        iTop  = Integer.parseInt(request.getParameter("hidT"));

        if (request.getParameter("btnU") != null

 && request.getParameter("btnU").compareTo("U") == 0)

iTop  -= 10;

        if (request.getParameter("btnD") != null

&& request.getParameter("btnD").compareTo("D") == 0)

iTop  += 10;

        if (request.getParameter("btnL") != null

&& request.getParameter("btnL").compareTo("L") == 0)

iLeft -= 10;

        if (request.getParameter("btnR") != null

&& request.getParameter("btnR").compareTo("R") == 0)

iLeft += 10;

        if (request.getParameter("btnM") != null

&& request.getParameter("btnM").compareTo("M") == 0) {

                iLeft = 400;

                iTop  = 200;

        }

    } else {

        iLeft = 400;

        iTop  = 200;

    }

%>

 

 

再来看一下JavaScript代码:FiveButtons.htm

FiveButtons

 

STYLE="position:absolute; top:100; left:400"

onClick="btnClick(this.value)">

STYLE="position:absolute; top:300; left:400"

onClick="btnClick(this.value)">

STYLE="position:absolute; top:200; left:300"

onClick="btnClick(this.value)">

STYLE="position:absolute; top:200; left:500"

onClick="btnClick(this.value)">

STYLE="position:absolute; top:200; left:400"

onClick="btnClick(this.value)">

 

大家看一看效果对于用户来说是不是一样?(不能发太长,分次来,待续)

 

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

我们都知道,浏览一个网页,有两个很主要的“电脑”在共同运行,一台是远程的,为你提供网页数据的“服务器”,一台是你正在使用的客户端电脑。

关键字: javascript java

在各种网页制作技术论坛中,常常有人询问javascript与Java有什么区别,甚至有人误认为javascript就是Java。javascript与Java确实有一定的联系,但它们并不像我们想象的那样联系紧密,甚至可以...

关键字: javascript java

nodejs和JavaScript的简单比较

关键字: nodejs javascript

js必备的内置对象,内置对象是ECMAscript标准以及定义好的,由浏览器厂商已经实现的标准对象 内置对象中封装了专门的数据和操作数据常用的API JavaScript中内置对象列表有

关键字: javascript 程序

3月16日,微软子公司、全世界最大的代码存放平台和开源社区Github表示,已同意收购代码分发初创公司NPM。微软高管表示,NPM目前拥有130万个软件包,每月支持750万次下载。微软希望永远让NPM对开发者保持开源和免...

关键字: javascript 微软

this是Javascript语言的一个关键字。 它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用。比如,   function test(){     this.x = 1;   }

关键字: javascript this

作为J2EE的重要组成部分的jsp和servlet规范中,会话(session)处理占有非常重要的位置。目前,很多资料都非常详细的讲解了会话跟踪如何处理。但是,针对会话控制却很少有人涉及,原本在ser

关键字: jsp servlet

虽然你可以把大段的代码放在脚本片段(scriptlet)内,但是绝大多数的Java代码属于可重复使用的名为JavaBea的组件。JavaBean类似于ActiveX控件:他们都能提供常用功能并且可以重

关键字: bean jsp

终于升星了~~在CSDN中辛辛苦苦爬了三载也做了三载的ASP开发这期间经常在CSDN中看到许多朋友讨论究竟学哪种语言的问题 在此我要说明的是其实我个人认为ASP并不是最好的WEB开发语言但也决不是最差

关键字: asp javascript

网页计算器 #container { width: 432px; margin: 0

关键字: function javascript
关闭
关闭