博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Ajax与用户交互的存储格式JSON
阅读量:7052 次
发布时间:2019-06-28

本文共 4352 字,大约阅读时间需要 14 分钟。

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

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

1     
2 3
4
apple
5
red
6
7 8
9
tomato
10
red
11
12 13
14
peach
15
pink
16
17 18
19
pitaya
20
green
21
22 23

 

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

 

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

1   
    2 3
  • apple:red
  • 4
  • tomato:red
  • 5
  • peach:pink
  • 6
  • piyata:green
  • 7 8

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

 

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

 

变量

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

于变量相关的性能问题:

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

 

数组

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

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

 

对象

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

1 //对象数据存储 2  3 var meatball = { 4      5     bread:"wang", 6     meat :"li", 7     cheese : "zhang" 8      9 };10 11 //返回对象的bread 12 alert(meatball.bread);

 

对象对效率的影响

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

 

JSON

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

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

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

 

1 //ajax JSON Salad 2 var ingredient = { 3     "fruit":[ 4         { 5             "name" : "apple", 6             "color" : "green" 7         }, 8         { 9             "name" : "tomato",10             "color" : "red"11         },12         {13             "name" : "peach",14             "color" : "pink"15         },16         {17             "name" : "pitaya",18             "color" : "white"19         },20         {21             "name" : "lettuce",22             "color" : "green"23         }24     ]25 };

 

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

这是我使用web storm创建的JSON,与之前的格式有所不同

1 { 2   "name": "contacts",                         //应用名称 3   "version": "0.0.1",                       //版本规定 4   "friends":[                                           //JSON数据块 5     { 6       "name": "伊卡洛斯", 7       "age": 20, 8       "email": "ikaros@sina.com" 9     },10     {11       "name": "泽村·英梨梨",12       "age": 18,13       "email": "ikaros@sina.com"14     },15     {16       "name": "千斗·五十铃",17       "age": 20,18       "email": "sndo@sina.com"19     },20     {21       "name": "saber",22       "age": 27,23       "email": "saber@sina.com"24     },25     {26       "name": "rider",27       "age": 32,28       "email": "rider@sina.com"29     },30     {31       "name": "智树",32       "age": 17,33       "email": "domo@sina.com"34     },35     {36       "name": "伊卡洛斯",37       "age": 20,38       "email": "ikaros@sina.com"39     }  ]40     “address”:[{41        "xx":"xx";42     }43         ]                                               //数据可以无限追加44 }

 

我会在稍后发表有关于使用JS中的Ajax异步交互与JSON数据结合的博客,欢迎交流

http://www.cnblogs.com/xuanya/p/6024838.html 为Ajax请求服务器JSON数据到客户端的实例

转载于:https://www.cnblogs.com/xuanya/p/6024687.html

你可能感兴趣的文章
10.Django ModelForm
查看>>
MXNET:卷积神经网络基础
查看>>
UIPageViewController 翻页、新手引导--UIScrollView:pagingEnabled
查看>>
[五]基础数据类型之Short详解
查看>>
ILOG Gantt 3.0 注册机
查看>>
自己实现几个基本函数
查看>>
谨防沦为DLL后门木马及其变种的肉鸡
查看>>
C#构造函数的重载
查看>>
遍历json 对象的属性并且动态添加属性
查看>>
json解析2
查看>>
比最差的API(ETW)更差的API(LTTng)是如何炼成的, 谈如何写一个好的接口
查看>>
Spring的IOC原理 通俗解释
查看>>
Spark下的FP-Growth和Apriori
查看>>
redash docker 运行
查看>>
Repeater嵌套使用
查看>>
Silverlight4.0教程之轻松操作剪切板
查看>>
GIF, JPEG和PNG
查看>>
线控的原理
查看>>
Android : Must Override a Superclass Method
查看>>
浮躁的程序员
查看>>