当前位置: 首页 > news >正文

购物网站开发技术无锡专业网站

购物网站开发技术,无锡专业网站,宁波seo推广怎么做,网站建设课程性质Web APIs 5 一、Window对象1、BOM2、定时器-延时函数3、JS执行机制4、location对象案例#xff1a;5秒钟之后跳转的页面 5、navigator对象6、histroy对象 二、本地存储本地存储 localStorage本地存储 sessionStorage存储复杂数据类型案例#xff1a;学生就业统计表字符串拼接… Web APIs 5 一、Window对象1、BOM2、定时器-延时函数3、JS执行机制4、location对象案例5秒钟之后跳转的页面 5、navigator对象6、histroy对象 二、本地存储本地存储 localStorage本地存储 sessionStorage存储复杂数据类型案例学生就业统计表字符串拼接新思路以后都用这个方法 map、join①渲染模块②新增模块③ 删除模块②新增模块③ 删除模块 一、Window对象 1、BOM BOM(Browser Object Model ) 是浏览器对象模型 页面属于DOM整个浏览器属于BOMDOM属于BOM window对象是一个全局对象也可以说是JavaScript中的顶级对象 像document、alert()、console.log()这些都是window的属性基本BOM的属性和方法都是window的。比如 window.document.querySelector()一般简写为document.querySelector() 所有通过var定义在全局作用域中的变量、函数都会变成window对象的属性和方法 window对象下的属性和方法调用的时候可以省略window 比如生命的全局的函数、变量 都挂在了window上 function fn() {console.log(111) } fn() window.fn()var num 10 console.log(num) console.log(window.num)2、定时器-延时函数 JavaScript 内置的一个用来让代码延迟执行的函数叫 setTimeout 一次性的 网页上一般有两种定时器①轮播图setInterval 间歇函数②广告延时函数setTimeout 语法 setTimeout(回调函数等待的毫秒数) setTimeout 仅仅只执行一次所以可以理解为就是把一段代码延迟执行, 平时省略window scriptsetTimeout(function() {console.log(时间到了);}, 2000) /script清除延时函数 let timer setTimeout(回调函数等待的毫秒数) clearTimeout(timer) 【注意点】 延时器需要等待所以后面的代码先执行 每一次调用延时器都会产生一个新的延时器 3、JS执行机制 浏览器有两个引擎一个引擎渲染HTML CSS另一个解析JSJS解析器 经典面试题 注意这两个的结果都是132 JavaScript 语言的一大特点就是单线程也就是说同一个时间只能做一件事。 这是因为 Javascript 这门脚本语言诞生的使命所致——JavaScript 是为处理页面中用户的交互以及操作DOM 而诞生的。比如我们对某个 DOM 元素进行添加和删除操作不能同时进行。 应该先进行添加之后再删除。 单线程就意味着所有任务需要排队前一个任务结束才会执行后一个任务。这样所导致的问题是如果 JS 执行的时间过长这样就会造成页面的渲染不连贯导致页面渲染加载阻塞的感觉。 为了解决这个问题利用多核 CPU 的计算能力HTML5 提出 Web Worker 标准允许 JavaScript 脚本创建多个线程。于是JS 中出现了同步和异步。 同步 前一个任务结束后再执行后一个任务程序的执行顺序与任务的排列顺序是一致的、同步的。比如做饭的同步做法我们要烧水煮饭等水开了10分钟之后再去切菜炒菜。 异步 你在做一件事情时因为这件事情会花费很长时间在做这件事的同时你还可以去处理其他事 情。比如做饭的异步做法我们在烧水的同时利用这10分钟去切菜炒菜。 他们的本质区别 这条流水线上各个流程的执行顺序不同。 【JS执行机制】 ① 先执行执行栈中的同步任务。 ② 异步任务放入任务队列中。 ③ 一旦执行栈中的所有同步任务执行完毕系统就会按次序读取任务队列中的异步任务于是被读取的异步任务结束等待状态进入执行栈开始执行 首先 JS 代码从上到下依次执行代码分为同步任务和异步任务把所有的同步任务放在执行栈里异步任务放在任务队列。 执行栈中所有同步任务执行完之后去看任务队列中是否有要执行的有的话放进执行栈 输出结果是 1243scriptconsole.log(1);console.log(2);setTimeout(function(){console.log(3);})console.log(4);/script4、location对象 location 的数据类型是对象它拆分并保存了 URL 地址的各个组成部分 window.location, 可以省略window 常用属性和方法 href 属性获取完整的 URL 地址对其赋值时用于地址的跳转 search 属性获取地址中携带的参数符号 后面部分 hash 属性获取地址中的啥希值符号 # 后面部分 reload** 方法用来刷新当前页面传入参数 true 时表示强制刷新 案例5秒钟之后跳转的页面 需求用户点击可以跳转如果不点击则5秒之后自动跳转要求里面有秒数倒计时 分析 ①目标元素是链接 ②利用定时器设置数字倒计时 ③时间到了自动跳转到新的页面 href属性 bodya hrefhttp://www.baidu.com支付成功span5/span秒钟之后跳转首页/ascriptconst a document.querySelector(a)let num 5let timeId setInterval(function() {num--a.innerHTML 支付成功span${num}/span秒钟之后跳转首页if(num 0) {clearInterval(timeId)location.href http://www.baidu.com}}, 1000)/script /bodysearch 属性 search 属性获取地址中携带的参数符号 后面部分 表单提交之后在地址栏的后面会有对应的数据 bodyform actioninput typetext nameusernameinput typepassword namepasswordbutton提交/button/form /body script// location.search提交表单之后在 控制台写这句话//search 属性获取地址中携带的参数符号 后面部分 /scripthash 属性 hash 属性获取地址中的哈希值符号 # 后面部分 后期vue路由的铺垫经常用于不刷新页面显示不同页面比如 网易云音乐 bodya href#/my我的/aa href#/friend关注/aa href#/download下载/a /bodyreload 方法 reload 方法用来刷新当前页面传入参数 true 时表示强制刷新 bodybutton classbtn刷新/button /body scriptconst btn document.querySelector(.btn)btn.addEventListener(click, function() {location.reload()}) /script5、navigator对象 navigator的数据类型是对象该对象下记录了浏览器自身的相关信息 常用属性和方法 通过 userAgent 检测浏览器的版本及平台 body这是PC端页面 /body script// 检测 userAgent浏览器信息!(function () {const userAgent navigator.userAgent// 验证是否为Android或iPhoneconst android userAgent.match(/(Android);?[\s\/]([\d.])?/)const iphone userAgent.match(/(iPhone\sOS)\s([\d_])/)// 如果是Android或iPhone则跳转至移动站点if (android || iphone) {location.href http://m.itcast.cn }})() /script这里是立即执行函数的另一种写法6、histroy对象 history 的数据类型是对象主要管理历史记录 该对象与浏览器地址栏的操作相对应如前进、后退、历史记录等 bodybutton后退/buttonbutton前进/button /body scriptconst back document.querySelector(button:first-child)const forward back.nextElementSiblingback.addEventListener(click, function() {history.back()})forward.addEventListener(click, function() {history.forward()}) /script二、本地存储 以前我们页面写的数据一刷新页面就没有了。随着互联网的快速发展基于网页的应用越来越普遍同时也变的越来越复杂为了满足各种各样的需求会经常性在本地存储大量的数据HTML5规范提出了相关解决方案。 1、数据存储在用户浏览器中 2、设置、读取方便、甚至页面刷新不丢失数据 3、容量较大sessionStorage 和 localStorage约 5M 左右 常见的使用场景https://todomvc.com/examples/vanilla-es6/ 页面刷新数据不丢失 本地存储只能存储字符串。 本地存储 localStorage 作用: 可以将数据永久存储在本地(用户的电脑), 除非手动删除否则关闭页面也会存在 特性 可以多窗口页面共享同一浏览器可以共享 以键值对的形式存储使用 【语法】: 存储数据 localStorage.setItem(key, value) 获取数据 localStorage.getItem(key) 删除数据 localStorage.removeItem(key) script//要存储一个名字localStorage.setItem(uname, pink老师) // 增localStorage.setItem(uname, red老师) // 改console.log(localStorage.getItem(uname)); // 查localStorage.removeItem(uname) // 删 /script本地存储 sessionStorage 【特性】 生命周期为关闭浏览器窗口 在同一个窗口(页面)下数据可以共享 以键值对的形式存储使用 用法跟localStorage 基本相同 存储复杂数据类型 存储 本地只能存储字符串,无法存储复杂数据类型 解决方式将复杂数据转换成 JSON 字符串存储本地存储中 语法JSON.stringify(复杂数据类型) scriptconst obj {uname: pink,age: 18,gender: 女}localStorage.setItem(obj, JSON.stringify(obj)) // 键值对 /script存了之后可以看到 JSON字符串是 {“uname”:“pink”,“age”:18,“gender”:“女”}。 属性和值有引号而且引号是统一的双引号。 取 因为存储的时候把对象变成了 JSON字符串存储所以取得时候要还原成对象 语法JSON.parse(JSON字符串) console.log(localStorage.getItem(obj));//这样得到的是字符串 console.log(JSON.parse(localStorage.getItem(obj))); //转换为对象案例学生就业统计表 添加且刷新后数据不会消失 删除 V:\Web\mycode\5-12学生就业统计表案例.html 模块分析 ①新增模块 输入学生信息数据会存储到本地存储中 ②渲染模块数据会渲染到页面中 ③删除模块点击删除按钮会删除对应的数据 渲染模块一定是从本地数据中读取因为这样才能保证数据不丢失 补充一个新知识: 字符串拼接新思路以后都用这个方法 map、join map方法join方法 map() map 可以处理数据并且返回新的数组 map 也称为映射。 映射是个术语指两个元素的集之间元素相互“对应”的关系 const arr [red, blue, green]arr.map(function(ele, index) { //回调函数 第一个参数 是值第二个参数是数组下标console.log(ele); //red blue greenconsole.log(index); // 0 1 2 })const newArr arr.map(function(item, i) {return item颜色 }) console.log(newArr) //red颜色 blue颜色 green颜色 join() join()方法用于把数组中的所有元素转换一个字符串 join参数数组元素是通过参数里面指定的分隔符进行分隔的空字符串()则所有元素之间都没有任何字符。 const arr [red颜色, blue颜色, green颜色] console.log(arr.join()) //red颜色blue颜色green颜色 console.log(arr.join(,)) //red颜色,blue颜色,green颜色 以逗号分隔 console.log(arr.join(?)) //red颜色?blue颜色?green颜色 以问号分割①渲染模块 渲染模块一定是从本地数据中读取因为这样才能保证数据不丢失 方法从本地数据中读取数据然后写进页面。 因为写进页面的代码为 trtd1001/tdtd欧阳霸天/tdtd19/tdtd男/tdtd15000/tdtd上海/tdtda hrefjavascript:删除/a/td/tr 我们是要把读取到的数据按照这种格式写进页面所以用到map方法。但是map方法得到的是数组形式所以用到 join 方法。 【总结】 核心步骤根据数据渲染页面。遍历数组根据数据生成 tr里面填充数据最后追加给tbody 1.渲染业务要封装成一个函数render 2.我们使用map方法遍历数组里面更换数据然后会返回有数据的 tr 数组 3.通过join方法把map返回的数组转换为字符串 4.把字符串通过innerHTML赋值给tbody ②新增模块 1.给form注册提交事件要阻止默认提交事件阻止默认行为) 2.非空判断如果年龄、性别、薪资有一个值为空,则return返回’输入不能为空’中断程序 注意 页面刷新的时候代码会重新执行一次 stuID的处理思路为 新增加的序号应该是最后一条数据的stuID1 stuId: arr.length ? arr[arr.length - 1].stuId 1 : 1, ③ 删除模块 1.采用事件委托形式给tbody注册点击事件 2.得到当前点击的索引号。渲染数据的时候动态给a链接添加自定义属性data-id“o” 到的是数组形式所以用到 join 方法。 【总结】 核心步骤根据数据渲染页面。遍历数组根据数据生成 tr里面填充数据最后追加给tbody 1.渲染业务要封装成一个函数render 2.我们使用map方法遍历数组里面更换数据然后会返回有数据的 tr 数组 3.通过join方法把map返回的数组转换为字符串 4.把字符串通过innerHTML赋值给tbody ②新增模块 1.给form注册提交事件要阻止默认提交事件阻止默认行为) 2.非空判断如果年龄、性别、薪资有一个值为空,则return返回’输入不能为空’中断程序 注意 页面刷新的时候代码会重新执行一次 stuID的处理思路为 新增加的序号应该是最后一条数据的stuID1 stuId: arr.length ? arr[arr.length - 1].stuId 1 : 1, ③ 删除模块 1.采用事件委托形式给tbody注册点击事件 2.得到当前点击的索引号。渲染数据的时候动态给a链接添加自定义属性data-id“o”
http://www.zqtcl.cn/news/695116/

相关文章:

  • 南昌手机建站模板18种禁用软件黄app
  • 备案的域名做电影网站wordpress伪静态cdn配置
  • 国家城乡住房建设部网站百度关键词首页排名
  • 安卓软件开发需要学什么软件北京百度推广优化公司
  • 用asp.net 做网站wordpress网址缩短
  • 中国工程建设交易信息网站仿蘑菇街wordpress主题
  • 网站需要怎么做做普通网站公司吗
  • 网站收录平台方法网站建设是不是都需要交费
  • 上海 政务网站建设情况营销模式有哪些 新型
  • 国内做免费视频网站有哪些苏州娱乐场所最新消息
  • 福田建设网站宿迁网站建设案例
  • 建立企业网站的目的和意义人力资源外包收费标准
  • 网站开发前后端分离湘潭seo磐石网络
  • 上海做网站找谁京东网站建设分析
  • 叶榭做网站青岛做网站建设价格
  • 有什么可以在线做奥数题的网站中国建设网官网下载
  • 网站加载特效代码网站建设5000费用
  • 网站切图谁来完成wordpress 谷歌登陆
  • 租房网站建设网站怎么黑
  • 文成做网站搜索引擎优化工具深圳
  • 网站源码下载平台小程序云开发费用
  • 网站建设的数字化和互联网化网站作品
  • 南京专业网站制作公司有哪些亚马逊网网站建设规划报告
  • app免费制作网站模板网站打开速度进行检测
  • 进下加强新闻宣传网站建设wordpress做论坛网站
  • 朝阳网站搭建公司淘宝导购网站备案
  • 京润珍珠企业网站优化洛阳做网站
  • 嘉定网站开发中山市区做网站公司
  • 可信赖的武进网站建设上海中小企业服务中心
  • 应用网站品牌官方网站