当前位置: 网站首页>小程序开发>网站制作

【网站建设】南京网站制作-南京网络公司-南京网页设计-南京网店美工-南京网站开发

发表日期: 2021-06-16 09:34:27 浏览次数:191

【网站建设】南京网站制作-南京网络公司-南京网页设计-南京网店美工-南京网站开发


网站建设.jpg


南京市,简称“宁”,古称金陵、建康 [1]  ,是江苏省会、副省级市、特大城市、南京都市圈核心城市 [2]  ,国务院批复确定的中国东部地区重要的中心城市、全国重要的科研教育基地和综合交通枢纽 [3]  。截至2019年,全市下辖11个区,总面积6587平方千米,建成区面积823平方千米 [4]  ,2020年常住人口931.47万人,城镇人口808.53万人,城镇化率86.8% [337]  。

南京地处中国东部、长江下游、濒江近海,是中国东部战区司令部驻地 [6]  ,地理坐标为北纬31°14′至32°37′,东经118°22′至119°14′ [7]  ,是国务院规划定位的长三角辐射带动中西部地区发展的重要门户城市 [8]  ,也是东部沿海经济带与长江经济带战略交汇的重要节点城市 [9]  。

南京属宁镇扬丘陵地区,以低山缓岗为主,属北亚热带湿润气候,水域面积达11%以上,是首批国家历史文化名城 [10]  ,中华文明的重要发祥地 [11]  ,长期是中国南方的政治、经济、文化中心 [10]  。南京早在100-120万年前就有古人类活动,35-60万年前已有南京猿人在汤山生活,有着7000多年文明史、近2600年建城史和近500年的建都史 [12]  。

南京是国家重要的科教中心,自古以来就是一座崇文重教的城市,有“天下文枢”“东南第一学”之称 [13]  ,明清中国一半以上的状元均出自南京江南贡院 [14]  。截至2020年,南京各类高等院校68所 [15]  ,其中111计划高校10所 [16]  、211高校8所 [17]  、双一流高校12所 [18]  、两院院士81人 [19]  ,均仅次于北京上海 [20]  ;全球科研城市20强排名,南京位列全球第8、中国第3 [21]  。

2020年8月,联合国人居署发布亚洲城市百强名单,南京位列亚洲第11,中国大陆第5 [22]  。


问:如何用 JS 一次获取 HTML 表单的所有字段 ?

考虑一个简单的 HTML 表单,用于将任务保存在待办事项列表中:

<form>
    <label for="name">用户名</label>
    <input type="text" id="name" name="name" required>

    <label for="description">简介</label>
    <input type="text" id="description" name="description" required>

    <label for="task">任务</label>
    <textarea id="task" name="task" required></textarea>

    <button type="submit">提交</button>
</form>

上面每个字段都有对应的的typeID和 name属性,以及相关联的label。 用户单击“提交”按钮后,我们如何从此表单中获取所有数据?

有两种方法:一种是用黑科技,另一种是更清洁,也是最常用的方法。为了演示这种方法,我们先创建form.js,并引入文件中。

从事件 target 获取表单字段

首先,我们在表单上为Submit事件注册一个事件侦听器,以停止默认行为(它们将数据发送到后端)。

然后,使用this.elementsevent.target.elements访问表单字段:

相反,如果需要响应某些用户交互而动态添加更多字段,那么我们需要使用FormData

使用 FormData

首先,我们在表单上为submit事件注册一个事件侦听器,以停止默认行为。接着,我们从表单构建一个FormData对象:

const form = document.forms[0];

form.addEventListener("submit", function(event) {
  event.preventDefault();
  const formData = new FormData(this);
});

除了append()delete()get()set()之外,FormData 还实现了Symbol.iterator。这意味着它可以用for...of 遍历:

const form = document.forms[0];

form.addEventListener("submit", function(event) {
  event.preventDefault();
  const formData = new FormData(this);

  for (const formElement of formData) {
    console.log(formElement);
  }
})

效果如下:

除了上述方法之外,entries()方法获取表单对象形式:

const form = document.forms[0];

form.addEventListener("submit", function(event) {
  event.preventDefault();
  const formData = new FormData(this);
  const entries = formData.entries();
  const data = Object.fromEntries(entries);
});

这也适合Object.fromEntries() (ECMAScript 2019)

为什么这有用?如下所示:

const form = document.forms[0];

form.addEventListener("submit", function(event) {
  event.preventDefault();
  const formData = new FormData(this);
  const entries = formData.entries();
  const data = Object.fromEntries(entries);

  // send out to a REST API
  fetch("https://mybj123.com", {
    method: "POST",
    body: JSON.stringify(data),
    headers: {
      "Content-Type": "application/json"
    }
  })
    .then(/**/)
    .catch(/**/);
});

一旦有了对象,就可以使用fetch发送有效负载。

注意:如果在表单字段上省略name属性,那么在FormData对象中刚没有生成。

总结

要从HTML表单中获取所有字段,可以使用:

  • this.elementsevent.target.elements,只有在预先知道所有字段并且它们保持稳定的情况下,才能使用。

使用FormData构建具有所有字段的对象,之后可以转换,更新或将其发送到远程API。


网站建设南京网站制作-南京网络公司-南京网页设计-南京网店美工-南京网站开发

400-111-6878
服务热线
顶部

备案号: 苏ICP备11067224号

CopyRight © 2011 书生商友信息科技 All Right Reserved

24小时服务热线:400-111-6878   E-MAIL:1120768800@qq.com   QQ:1120768800

  网址: https://www.768800.com  网站建设上往建站

关键词: 网站建设| 域名邮箱| 服务器空间| 网站推广| 上往建站| 网站制作| 网站设计| 域名注册| 网络营销| 网站维护|

企业邮箱| 虚拟主机| 网络建站| 网站服务| 网页设计| 网店美工设计| 网站定制| 企业建站| 网站设计制作| 网页制作公司|

400电话办理| 书生商友软件| 葬花网| 调温纤维| 海洋馆运营维护| 北京保安公司| 殡仪馆服务| 殡葬服务| 昌平殡葬| 朝阳殡葬|

预约专家

欢迎您免费咨询,请填写以下信息,我们收到后会尽快与您联系

  

服务热线:400-111-6878