GVKun编程网logo

用户交互时,AJAX调用并不总是加载(用户交互时,ajax调用并不总是加载失败)

24

对于用户交互时,AJAX调用并不总是加载感兴趣的读者,本文将会是一篇不错的选择,我们将详细介绍用户交互时,ajax调用并不总是加载失败,并为您提供关于Ajax——ajax调用数据总结、Ajax与用户交

对于用户交互时,AJAX调用并不总是加载感兴趣的读者,本文将会是一篇不错的选择,我们将详细介绍用户交互时,ajax调用并不总是加载失败,并为您提供关于Ajax——ajax调用数据总结、Ajax与用户交互的JSON数据存储格式、AJAX调用并清除JSON,但语法错误:缺少; 声明前、ajax调用需要用户名和密码的有用信息。

本文目录一览:

用户交互时,AJAX调用并不总是加载(用户交互时,ajax调用并不总是加载失败)

用户交互时,AJAX调用并不总是加载(用户交互时,ajax调用并不总是加载失败)

我遇到一些涉及PHP&的问题.使用jQuery的AJAX.为了使整个说明更容易,我将简单地提供一个指向我正在工作的网站的链接,如果您使用“报价计算器”选项卡并按照以下步骤进行操作,则应该可以理解我的问题

http://bothrealities.very-dev.co.uk/green-it

万一您不知道,这里有一个解释:

当我单击单选按钮时;模型部分中的单选按钮(可通过AJAX调用来自PHP文件和db的数据),右侧的信息框并不总是填充,有时看起来好像数据卡在了缓存中.您可以单击一个模型,然后再次单击该模型时,您选择的先前模型将填充在信息框中(就像是单击一遍一样)

现在,我不确定用户单击按钮的速度是否如此,从而中断了原始的AJAX调用?

我不知道是否需要禁用页面/禁用灰色并有一个加载轮,直到数据返回为止,这样用户才能不干扰该过程吗?

抱歉,如果上述说明令人困惑,我确实希望您访问上面的链接并自己尝试,这样理解起来非常容易.

预先非常感谢可以解决此问题的任何人,我什至在这篇文章中可能会悬赏一小笔.

谢谢,

担.

P.s尚不确定如何添加赏金,对不起.

编辑:::

    function productString(product, Box) {
        $.get("http://<? echo ROOT; ?>includes/forms.PHP", { product: product }, function(data) {
            $("#loadingModel").append(data);
        });

        $.get("http://<? echo ROOT; ?>includes/forms.PHP", { Box: Box }, function(data) {
            $("#content-right").empty();
            $("#content-right").append(data);
            $("#content-right").jScroll();
        });
    }

    function modelString(model, BoxModel) {
        $.get("http://<? echo ROOT; ?>includes/forms.PHP", { model: model }, function(data) {
            $("#loadingData").empty().append(data);
        });

        $.get("http://<? echo ROOT; ?>includes/forms.PHP", { BoxModel: BoxModel }, function(data) {
            $("#BoxModel").empty().append(data);
        });
    }

解决方法:

有时您的http://bothrealities.very-dev.co.uk/includes/forms.php?boxModel=1在http://bothrealities.very-dev.co.uk/includes/forms.php?model=xxxxx结束之前结束,因此第二个请求返回的数据不是您想要的.

您也可以通过在第二个“ GET”中传递模型参数来尝试.

Ajax——ajax调用数据总结

Ajax——ajax调用数据总结

在做人事系统添加批量修改的功能中,需要将前台中的数据传给后台,后台并执行一系列的操作。通过查询和学习了解到可以通过ajax将值传入到后台,并在后台对数据进行操作。

说的简单点,就是ajax调用后台的方法。通过学习和实践,学习了几种ajax调用数据的几种形式,现在总结一下:

1. Ajax调用无参的后台方法的数据

Jquery前台代码:

       //ajax调用无参数后台方法
        $(function () {
            $("#btnok").click(function () {
                $.ajax({
                    type:"post",//ajax的方式为post(get方式对传送数据长度有限制)
                    url: "demo.aspx/Hello",//demo.aspx为目标文件,Hello为目标文件中的方法
                    contentType: "application/json",//传值方式
                    success: function (data) {      //成功回传值后触发的方法
                        alert(data.d);          //后台返回的参数
                    }
                })
            })
        });

前台表单控件:

        <input id="btnok" type="button" value="单击返回hello" />

后台代码:

        //ajax调用的无参数方法
        [WebMethod]
        public static string Hello()
        {
            return "Hello Ajax!";
        }
运行结果:



2. Ajax调用有参后台方法中的数据

Jquery前台代码:

       //ajax调用有参数后台方法
        $(function () {
            $("#btnName").click(function () {
                var strname = $("#txtName").val();   //strname获得文本框中输入的值
                $.ajax({
                    type: "post",//ajax的方式为post(get方式对传送数据长度有限制)
                    contentType: "application/json",//传值方式
                    url: "demo.aspx/getName",//demo.aspx为目标文件,getName为目标文件中的方法
                    data: "{strName:'" + strname + "'}",//strName为后台方法的参数,strname为文本框中输入的值
                    contentType: "application/json",//传值方式
                    success: function (result) {      //成功回传值后触发的方法
                        alert(result.d);          //后台返回的参数
                    }
                })
            })
        });

前台表单控件:

            <input id="txtName" type="text" /><input id="btnName" type="button" value="确定" />

后台代码:

        //ajax调用的带参数的方法         
        [WebMethod]       
        public static string getName(string strName)
        {
            return "欢迎"+strName;
        }

运行结果:



3. Ajax调用后台方法返回数组的数据

Jquery前台代码:

      //ajax调用后台方法返回数组
        $(function () {
            $("#btnReArr").click(function () {
                $.ajax({
                    type: "post",//传值方式
                    url: "demo.aspx/GetArray",//demo.aspx为目标文件,GetArray为目标文件中的方法
                    contentType: "application/json",//传值方式
                    success: function (result) {      //成功回传值后触发的方法
                        alert(result.d);          //后台返回的参数
                    }
                })
            })
        });

前台表单控件:

            <input id="btnReArr" type="button" value="单击返回数组" />

后台代码:

       //ajax调用返回数组的方法
        [WebMethod]
        public static List<string> GetArray()
        {
            List<string> li = new List<string>();
            for (int i = 0; i < 10; i++)
                li.Add(i + "");
            return li;
        }    

运行结果:




4. Ajax调用xml中的数据

Jquery前台代码:

     //ajax调用xml中的数据
        $(function () {
            $("#btnMaXML").click(function () {
                $.ajax({
                    dataType: 'xml',//ajax的方式为post(get方式对传送数据长度有限制)
                    url: "demoXML.xml",//直接写xml的名字
                    success: function (xml) {      //成功回传值后触发的方法
                        //查找xml元素      
                        $(xml).find("data>item").each(function () {
                            var $dm = $(this);
                            var $id = $dm.find("id");   //获取出id字段的值
                            var $class = $dm.find("class");//获取出class字段的值
                            alert($id.text()+","+$class.text());   
                        })
                    }
                })
            })
        });

前台表单控件:

            <input id="btnMaXML" type="button" value="单击返回xml中数据" />

xml代码:

<?xml version="1.0" encoding="utf-8" ?> 
<data>     
  <item>     
    <id>1</id>     
    <class>语文</class>     
  </item>     
  <item>     
    <id>2</id>     
    <class>数学</class>    
  </item>     
</data>    

运行结果:

对于利用ajax调用后台的方法,也有一定的局限性,因为他的后台方法是静态的,所以在方法中利用表单中的控件就有一定的困难。但是这种从前台传值到后台的方法比较简单也更易于理解。

(免费送上自己写的源码地址:http://download.csdn.net/detail/suneqing/7265593)

Ajax与用户交互的JSON数据存储格式

Ajax与用户交互的JSON数据存储格式

数据存储是javascript的核心功能,适当的存放好数据,就有利于我们组织起结构,又能使应用程序稍后访问这些内容更加容易。这篇文章给大家介绍了ajax与用户交互的json数据存储格式,对ajax感兴趣的朋友一起看看ajax与用户交互的json数据存储格式吧

数据存储是JavaScript的核心功能,这是一个在学习前期的一个容易让人迷惑的问题。它并不是那种像页面滑动、幻灯片展示、淡入淡出等吸引人眼球的特效。适当的存放好数据,就有利于我们组织起结构,又能使应用程序稍后访问这些内容更加容易。JavaScript提供了各种不同的数据存储方式,它是一个从基本到未来走向的演化模式:

XML代表可扩展标记语言,是一种比较灵活的数据格式,很多应用程序存储数据都喜欢用到它,结构像HTML,也包含元素,标签以及属性,模型都一样。它的一大优势在于它是一种可扩展的格式,你并不会受制于某种预设的数据结构;并且它还符合DOM标准,使用AJAX调用获取到的数据就像解析HTML一样,通过相应的DOM方法和属性解析它:


<ingredient>
<prison>
<name>apple</name>
<color>red</color>
</prison>
<prison>
<name>tomato</name>
<color>red</color>
</prison>
<prison>
<name>peach</name>
<color>pink</color>
</prison>
<prison>
<name>pitaya</name>
<color>green</color>
</prison>
</ingredient>
登录后复制

但是XML的一个严重的缺陷在于它不能用于跨域名的Aiax调用,也就是说每一个Ajax调用的XML数据都必须和执行调用的脚本处于同一域名内,否则请求会失败。

HTML存储也相似,它与Ajax结合起来最简单。采用这种方式的数据格式的重要因素是速度,HTML代码段无需在客户端解析就能直接将其输出到DOM之中,所以我们不需要再额外的编写JavaScript代码解析HTML。


<ul>
<li><a href="boke.js">apple:red</a></li>
<li>tomato:red</li>
<li>peach:pink</li>
<li>piyata:green</li>
</ul>
登录后复制

说说它的缺点,它存储的数据可能和HTML代码混合在一起,所以说可维护性降低。另外在编写处理代码时,开发者可能需要在服务器端做一些精细的控制手段。

以下是使用JavaScript进行数据存储的手段,循序渐进…

变量

JavaScript最为基础的数据存储方式,它接受字符串、数值、布尔等。最核心的内容是它的作用域问题。

于变量相关的性能问题:

变量在声明完之后,就会被缓存到JavaScript文件中,于是在作用域内就可以反复的使用它们了,获取变量的开销微乎其微,只要数据的使用次数大于1,就应该将其存入变量。

数组

数组跟普通数组、关联数组和多维数组,它们都是元素列表,这种形式是各种数据存储中非常灵活的一种。掌握了数组最基本的形式,也会对其他复杂形式的运用大有脾益。数组元素的访问合一处是常见的基本交互代码。鉴于数组这种数据存储类型的重要性,JavaScript为数组交互操作提供了大量的专属方法:

.join() 方法 可以指定某个字符可作为数组内每个元素的连接符;slice() 方法可以输出数组中某个范围内的元素;shift()和unshift() 方法 分别用于在数组头部移除或新增元素;pop() 方法 用于移除并返回数组中的最后一个元素;concat() 方法 用于将多个数组拼接成一个数组,按参数的先后而定;sort()方法 可以按照字母表顺序或自定义顺序来排列数组的元素,但是只会根据首字符排序,一般都是错误的。

对象

在数据变得更加复杂、更加难以管理的情况下,我就会选择将数组转换为对象。因为对象的存储方式更加易读。


//对象数据存储
var meatball = {
bread:"wang",
meat :"li",
cheese : "zhang"
};
//返回对象的bread 
alert(meatball.bread);
登录后复制

对象对效率的影响

上面的代码只有一层,然而它是可以无限嵌套的。对象能更好的组织代码,提高模块化的程度。不过与此同时,还是需要考虑性能和可维护性的权衡问题,因为它需要寻找这三者中的一个。如果是运用面向对象编程技术,嵌套达到3层及以上,就会引发性能问题;但是在服务器端运用时就不是这样了,所以前端开发者要决定什么时候使用面向对象编程技术。

JSON

JSON是一种易于同jacascript 集成的数据格式,它通常是在用JavaScript调用外部服务器时使用的。JSON数据存放于独立的文件中,而且通常位于另一台完全不同的服务器上。它现在是最常见的一种调用API服务时所使用的数据格式,人们之所以选中它,是因为此格式非常易于阅读。起初,JSON格式是作为一种XML格式的替代方案而出现的,但很快它就在数据交换领域占据了主流的地位。它是一种轻量级的数据格式,易于通过远程Ajax调用进行跨域名访问。尽管JavaScript对JSON格式的解析提供了原生的支持,但它还是一种独立于平台的格式,客户端与服务器端在数据交换时都可以使用。

由于JSON格式具备跨域名访问的能力,所以为了防止一切恶意行为,我们务必只使用从可信的数据源中获取JSON。

这是一个 Salad.json 数据文件:


//ajax JSON Salad
var ingredient = {
"fruit":[
{
"name" : "apple",
"color" : "green"
},
{
"name" : "tomato",
"color" : "red"
},
{
"name" : "peach",
"color" : "pink"
},
{
"name" : "pitaya",
"color" : "white"
},
{
"name" : "lettuce",
"color" : "green"
}
]
};
登录后复制

JSON最常见的用途就是配合API调用,在于API为基础的网络程序开发环境中,使用何种后端语言进行开发,数据格式都无需改变。

以上所述是小编给大家介绍的Ajax与用户交互的JSON数据存储格式,希望对大家有所帮助!!

相关推荐:

原生JS写Ajax的请求函数功能的实例分享

全面总结基于jQuery中ajax的相关方法

Ajax应该如何使用

以上就是Ajax与用户交互的JSON数据存储格式的详细内容,更多请关注php中文网其它相关文章!

AJAX调用并清除JSON,但语法错误:缺少; 声明前

AJAX调用并清除JSON,但语法错误:缺少; 声明前

我正在使用以下代码进行跨域JSONP调用:

jQuery.ajax({
        async: true,url: 'http://mnews.hostoi.com/test.json',dataType: 'jsonp',method: "GET",error: function (jqXHR,textStatus,errorThrown) {
            console.log(textStatus + ': ' + errorThrown);
        },success: function (data,jqXHR) {
            if (data.Error || data.Response) {
                exists = 0;
            }
        }
    });

在Firebug中进行调试时,出现以下错误:

在此处输入图片说明

SyntaxError: missing ; before statement

但是,当我通过jsonlint.com之类的工具传递我的json对象(可通过JQ代码中的链接获得)时,它说这是有效的JSON。而且我也没有发现任何异常。它怎么可能返回语法错误?是我没有得到的一些JSONP详细信息还是什么?

JSON样本

{"news":[ {
  "sentences": [
    "Neuroscientists have discovered abnormal neural activity...","The researchers found that these mice showed many symptoms...","\"Therefore,\" the study authors say,\"our findings provide a novel.."
  ],"summaryId": "ZJEmY5","title": "Abnormal neural activity linked to schizophrenia"
}]}

提前致谢。

ajax调用需要用户名和密码

ajax调用需要用户名和密码

我是Ajax新手,所以这可以解释我的问题。

我正在打以下电话

                   $.ajax({
                   url: '<?php echo site_url('something/somethingelse')?>',type:'POST',username: 'username',password: 'password',data: { parm1 : 'A',parm2 : 1,parm3 : 2 },dataType: 'json',success: function(output_string){
                   }

用户名和密码是我用来登录服务器的用户名和密码。

如何在JavaScript中安全地表示它们?我知道我可以将它们存储在变量中并在Ajax调用中使用变量-
但是变量将存在于javascript文件中,并且任何可以使用允许您查看javascript的调试器的人都可以看到。

有没有办法隐藏某些javascript文件?javascript是否具有等效的属性文件?

关于用户交互时,AJAX调用并不总是加载用户交互时,ajax调用并不总是加载失败的问题我们已经讲解完毕,感谢您的阅读,如果还想了解更多关于Ajax——ajax调用数据总结、Ajax与用户交互的JSON数据存储格式、AJAX调用并清除JSON,但语法错误:缺少; 声明前、ajax调用需要用户名和密码等相关内容,可以在本站寻找。

本文标签: