当前位置:首页 > 高尔夫球资讯 > 正文内容

每天10个前端知识点:杂技

杏彩体育3年前 (2023-02-28)高尔夫球资讯243

个人博客已上线,欢迎前去访问评论!

无媛无故 - wangchloe的个人博客

以下内容若有问题烦请即时告知我予以修改,以免误导更多人。

toString() && valueOf()JSON stringify & parse+new Date()Array.prototype.slice.call(arguments, 0) 剖析JS Bridge建立Native与H5间通信Hybrid通信原理JS Bridge

有些平时碰到的很零碎的东西我就随便插入到这个章节里了。

1. toString() && valueOf()

toString() 把一个逻辑值转换为字符串,并返回结果。

valueOf() 返回Boolean对象的原始值

源自知乎

这两个方法一般是交由JS去隐式调用,以满足不同的运算情况。

在数值运算里,会优先调用valueOf(),如a+b;

在字符串运算里,会优先调用toString(),如alert(c)。
<script> // 该示例来源于脚本之家 var bbb = { i: 10, toString: function() { console.log(toString); return this.i; }, valueOf: function() { console.log(valueOf); return this.i; } } alert(bbb); // 10 toString alert(+bbb); // 10 valueOf alert( + bbb); // 10 valueOf alert(String(bbb)); // 10 toString alert(Number(bbb)); // 10 valueOf alert(bbb == 10); // true valueOf alert(bbb === 10); // false </script>
<script> console.log({ valueOf: function() { return 20; } } * { valueOf: function() { return 30; } }); // 600 </script>

2. JSON stringify & parse

json2.js - 引入解决IE7及以下版本JSON未定义问题。JSON.stringify(object); 对象 -> 字符串 将对象字符串序列化成标准JSON字符串

eg: {a:1,b:2} -> "{"a":1,"b":2}"

JSON.parse(str); 字符串 -> json对象 将字符串序列化成对象

{"name":"wangchloe","age":"22"} ->

{ age: "22", name: "wangchloe", _proto: Object }
<a href="https://www.baidu.com/" attr1=13>baidu.com</a>
<script> var oA = document.querySelector(a); console.log(oA.getAttribute(attr1)); // 13 oA.setAttribute(attr1, 14); var num = oA.getAttribute(attr1); console.log(oA.getAttribute(attr1)); // 14 console.log(typeof number); // string 直接设置自定义属性只能得到string类型 oA.setAttribute(attr1, JSON.stringify({name: 14})); var num2 = oA.getAttribute(attr1); console.log(num2); // {"name": "14"} console.log(JSON.parse(num2)); // Object {name: "14"} // name: "14" // -> _proto_: Object console.log(JSON.parse(num2).name); // 14 console.log(typeof JSON.parse(num2).name); // number JSON转化得到了真正类型 </script>

3. +new Date()

<script> s = new Date().toString(); // "Wed May 17 2017 11:00:16 GMT+0800 (中国标准时间)" t = (+new Date()).toString(); // "1494990039861" // +new Date(); 等同于 new Date().getTime(); 简略写法,得到毫秒 </script>

4. Array.prototype.slice.call(arguments, 0) 剖析

将具有length属性的对象转成数组

<script> // array.js slice的内部实现 function slice(start, end) { var len = ToUint32(this.length), result = []; for (var i = start; i < end; i++) { result.push(this[i]); } return result; } </script>
<script> // 传入arguments类数组,调用Array.prototype.slice原型方法 // 并用call()方法,将作用域限定在arguments中 // 这里Array.prototype就可以理解为arguments // 参数0为slice()方法的第一个参数,即开始位置索引,返回整个数组。 Array.prototype.slice.call(arguments, 0); </script>

5. JS Bridge建立Native与H5间通信

Hybrid通信原理

背景:原生APP开发中有一个webview的组件(Android中是webview,iOS7以下有UIWebview,7以上有WKWebview),这个组件可以加载Html文件。

IOS

Object-C可直接调用js,只需调用stringByEvaluatingJavaScriptFromString即可,可直接获取js返回值。js不可直接调用Object-C,利用 shouldStartLoadWithRequest,需拦截每个url,对指定的schema进行拦截做相应的本地方法。

Android

Java可直接调用js,但不可直接获取js返回值。Java注册addJavascriptInterface 后,js可直接调用Native的接口,并获取Native的返回值。让Java跟Javascript更加亲密通过 shouldOverrideUrlLoading,也还是拦截Web的所有URL请求来达到通信的目的。

基础通信存在以下问题

Android4.2以下,addJavascriptInterface方式有安全漏洞

iOS7以下,js无法调用Native

JS Bridge

url scheme交互方式是一套现有的成熟方案,可以完美兼容各种版本,不存在上述问题。

通过JSBridge(JS和Native通信机制),H5页面可以调用Native的api,Native也可调用H5页面的方法或者通知H5页面回调。

JSBridge的核心原理

原理:

(1)初始化创建的一个style.display=none 的iframe,并将iframe.src设置为自有协议,每次js需要与Native通信时,js端主动调用iframe.src即可,Native收到请求通知后,反向调用fetchQueue(可见源码)获取消息内容;若Native需要与js通信,直接调用js,并获取返回值

(2)

IOS

js->Native:js将要发送的消息存放在js端->调用iframe.src,触发通知Native->Native拦截请求,调用js bridge里面的fetchQueue并获取返回的消息内容,处理消息->将需要返回的数据通过直接调用js的方式,让js处理

Android

js->Native: 通过 shouldOverrideUrlLoading 携带Js的返回值

(3)Native->js: Native可直接调用Js并获取返回的内容
<script> function bridgeApp(protocol) { var iframe = document.createElement("iframe"); var iframeStyle = document.createAttribute("style"); var iframeSrc = document.createAttribute("src"); iframeStyle.nodeValue = "display:none;width:0;height:0;"; iframeSrc.nodeValue = protocol; iframe.setAttributeNode(iframeStyle); iframe.setAttributeNode(iframeSrc); document.body.appendChild(iframe); setTimeout(function() { document.body.removeChild(iframe); }, 250); } </script>
连续五篇讲述Hybrid以及JSBridge解决方案

更多内容可以订阅本人微信公众号,一起开启前端小白进阶的世界!

公众号是坚持日更的,不发文的时候推送一些我觉得好用的前端网站或者看到的一些问题的解决方案,也更便于大家交流,就酱。

微信公众号:无媛无故

扫描二维码推送至手机访问。

版权声明:本文由杏彩体育-专注全球体育资讯发布,如需转载请注明出处。

本文链接:http://www.redirected.net/?id=12484

分享给朋友:

“每天10个前端知识点:杂技” 的相关文章

贵州省高尔夫球队出征全国高尔夫球锦标赛

贵州省高尔夫球队出征全国高尔夫球锦标赛

原标题:贵州省高尔夫球队出征全国高尔夫球锦标赛 关注我们 10月24日,贵州省高尔夫球队参加2022全国高尔夫球锦标赛出征仪式在清镇体育训练基地举行。 出征仪式 2022全国高尔夫球锦标赛由中国高尔夫球协会、重庆市体育局主办,将于11月3日至11...

赵丽颖和地产大佬,关之琳的高尔夫球,鞠婧祎纯天然,吴宣仪收礼

赵丽颖和地产大佬,关之琳的高尔夫球,鞠婧祎纯天然,吴宣仪收礼

鞠婧祎每次营销自己没有整容就会被吐槽,最近她又拿出十年前她的练舞照企图来证明她没有做过脸部修复术,而大众都看出来她的照片也是经过精心P了的,她一直活在自己是天然美女的幻想中。 张庭带着女儿出镜卖惨,两人都哭不出来,提前在手上抹了洋葱汁,但她这种自欺欺人的洗白方式...

关之琳曾因“高尔夫球”事件赚了两千万,女星豪放起来真不要命!

要说我国娱乐圈中的女神级女星,关之琳一直是我们避不开的一个名字,她颜值巅峰的时候曾是无数人心目中的梦中女神! 不仅普通粉丝喜欢她,在圈内也有很多艺人对她十分青睐,例如刘德华、张学友等人都是她的至交好友。 对于她这样的女神级艺人,香港商业圈中的那些大佬肯定也早就仰慕有加,而关...

获评国家生态文明建设示范区!江门恩平都藏着哪些“绿色”密码?

获评国家生态文明建设示范区!江门恩平都藏着哪些“绿色”密码?

11月19日 生态环境部公布第六批 国家生态文明建设示范区名单 江门恩平市上榜 荣膺生态文明建设方面的 “国字号”荣誉 这是继江门市新会区...

高尔夫球车驾驶技巧,注意以下几点

平常我们在电视上看到的高尔夫球车是非常容易驾驶的,对于操作的要求不高,仪表台非常简单明了,就和电动车的操作很相似。不过不同的高尔夫球车也是存在差异的,具体要看你选择什么样的电动车,不同座位和配置的高尔夫球车价格也不相同,操作上有一点小差异,不过影响不大。那么问题就来了,怎么才能快速的上手一...

前半生是恃靓行凶的樊胜美,后半生只为自己活,55岁的关之琳终于找到钱和爱的正确打开方式

前半生是恃靓行凶的樊胜美,后半生只为自己活,55岁的关之琳终于找到钱和爱的正确打开方式

点击上方 蓝字 ▲ 关注订阅 她刊 好看的人都置顶了她 每一季的《我们来了》,都要请到一位老牌大美女,而这一季,是关之琳。 55岁的关之琳,走起秀来,还是让人恍然想起她风华绝代的那些年月,还是能让吴秀波和汪涵都看呆的程度。...