初识 Dojo

过去项目中使用过prototype、mootools、还有微软的ASP.Net Ajax,早在dojo0.3版本时就注意到它的存在,当时认为ajax的框架使用哪个都一样,prototype1.4版本时代码非常精简好用,写ajax异步刷新代码、web页面操作、浏览器的兼容都不错,现在发现dojo太强大了,几乎包含了prototype/mootools/ext核心功能,core/dijit/dojox三剑客至少从表面上看,可以解决大部分项目中对客户端体验要求和实际需求。但Google搜索了一番,发现对dojo评价褒贬不一,比如zerozone翻译的《 Ext vs. Dojo 》,并且对dojo widgets也存在 一些争议 ,不过是2007年初的事情了,不知道最新的1.1版本表现如何,不管这些了,因为工作技术的要求,看着IBM、SUN、BEA(现在已经被Oracle收购)等重量级产商的支持,准备义无反顾上Dojo!

    学习嘛,还是从最基础开始,玩一个基本ajax,参照《 The Book of Dojo 》。

    用VS2005新建一个ASP.Net项目(JSP/PHP/Ruby均可,不影响测试Dojo),看到下面这段代码,相信不用多说什么了

< html >
    
< head >
        
< title > Dojo: Hello World! </ title >
        
<!-- section 1 -->
        
< style  type"text/css" >
            @import "dojoroot/dijit/themes/tundra/tundra.css";
            @import "dojoroot/dojo/resources/dojo.css";
        
</ style >
        
< script  type ="text/javascript"  src ="dojoroot/dojo/dojo.js"  djConfig ="parseOnLoad:true" ></ script >
        
<!-- section 2 -->
        
< script  type ="text/javascript" >
            
//  Load Dojo's code relating to the Button widget
            dojo.require( " dijit.form.Button " );
        
</ script >
        
< script >
        
function  helloCallback(data, ioArgs)  {
            alert(data);
        }

        
function  helloError(data, ioArgs)  {
            alert(
' Error when retrieving data from the server! ' );
        }
        
        
</ script >
    
</ head >

    
< body  class ="tundra" >
        
< button  dojoType ="dijit.form.Button"  id ="helloButton" > Hello World!
        
< script  type ="dojo/method"  event ="onClick" >
            dojo.xhrGet(
{
                url: 
' response.txt ' ,
                load: helloCallback,
                error: helloError
                    }
);
        
</ script >
        
</ button >
    
</ body >
</ head >


    helloCallback作为回调函数,异步请求的发送通过dojo.xhrGet完成,helloError处理异常,值得注意的是"dojo.require("dijit.form.Button");",引入了dojo的button widget,并且可直接用于html ui构建中,有点类似于服务器端代码顶端的引用,符合OO程序员的习惯,运行页面,直接点击button就可以看到效果。

    上面例子显示的结果是response.txt中的文本,如果需要增加服务器端的处理,可以将url改成"HelloWorldResponseGet.aspx",通过GET方式传输。

Response.ContentType  =   " text/plain " ;
Response.Write(
" Hello  "   +  Request.QueryString[ " myname " +   " , welcome to the world of Dojo!\n " );
Response.End();


    ASP.Net一定要加上"Response.End();",否则返回的结果会包含html段。原来的页面更改为:

< html >
    
< head >
        
< title > Dojo: Hello World! </ title >
        
<!-- section 1 -->
        
< style  type"text/css" >
            @import "dojoroot/dijit/themes/tundra/tundra.css";
            @import "dojoroot/dojo/resources/dojo.css";
        
</ style >
        
< script  type ="text/javascript"  src ="js/dojo/dojo.js"  djConfig ="parseOnLoad:true" ></ script >
        
<!-- section 2 -->
        
< script  type ="text/javascript" >
            
//  Load Dojo's code relating to the Button widget
            dojo.require( " dijit.form.Button " );
        
</ script >
        
< script >
        
function  helloCallback(data, ioArgs)  {
            alert(data);
        }

        
function  helloError(data, ioArgs)  {
            alert(
' Error when retrieving data from the server! ' );
        }
        
        
</ script >
    
</ head >

    
< body  class ="tundra" >
        
< button  dojoType ="dijit.form.Button"  id ="helloButton" > Hello World!
        
< script  type ="dojo/method"  event ="onClick" >
            dojo.xhrGet(
{
                url: 
' HelloWorldResponseGet.aspx ' ,
                load: helloCallback,
                error: helloError,
                content: 
{myname: dojo.byId( ' name ' ).value }
                    }
);
        
</ script >
        
</ button >
        Please enter your name: 
< input  type ="text"  id ="name" >
    
</ body >
</ head >


    dojo.xhrGet的参数content用来描述传输的参数,页面增加了一个input元素,dojo.byId?即使没有接触过dojo,估计也能猜到是getElementById()。看运行效果:


    输入名字,点击"Hello World!"。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
**数字乡村解决方案摘要** **国家战略与乡村振兴** 中国正实施国家大数据战略,以加快数字中国的建设,整合数据资源,保障数据安全,并推动产业升级。2023年中央一号文件强调了乡村振兴战略,旨在通过产业兴旺、生态宜居、乡风文明、治理有效和生活富裕五大方面,实现农业农村现代化。 **数字乡村建设的重要性** 数字乡村建设是乡村振兴战略的重要组成部分,通过整合资源数据,推动物联网和遥感技术在农业中的应用,促进农业现代化。它被视为促进乡村转型发展的新方向,是数字化在农业农村经济社会发展中的应用。 **关键要素与效益** 数字乡村建设的关键要素包括数据资源整合、产业促进、农业发展规模化和标准化,以及改善乡村生活服务体系。预期效益包括提升国家治理能力,实现政府决策科学化和社会治理精准化,同时推动公共服务高效化。 **体系架构与数据融合** 数字乡村的体系架构包括乡村生态、基层治理、慧治、慧享、慧融、慧美、慧智和慧图等多个方面,实现城乡、政企、农户各级平台及服务的融合。数据融合是核心,整合乡村人口、产值、环境监测等多方面数据,为乡村治理和产业发展提供支撑。 **多业务协同与智慧治理** 数字乡村通过多业务协同应用平台,实现乡村物联网的布局和触达,涵盖农业生产、农资厂商、消费者等环节。区块链技术在农产品质量溯源中的应用,确保了产品全过程可追溯。乡村智慧治理通过村务管理、财务管理等方面提升治理效能,实现绿色发展理念。综合服务体系通过“互联网+服务”模式,提供便民服务和乡村经济发展支持,推动乡村全面振兴。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值