有一件事要说一下哦, 《UIWebView与javascript交互一》这篇博客被几个网站给转载了,很开心,但是开心之余有一点觉得要说一下,大家转载别人的文章的时候记得说明一下转载的出处,有两方面的原因,第一就是尊重作者的劳动成果,另一方面,由于博客里有的时候有一些demo,但是转载的人并没有把demo的下载地址给贴出来,给看到博客的同学带来了很大的不便。
接上篇,我们已经实现了通过html按钮来传数据到oc页面,但是没有实现通过oc页面传数据到js页面,并修改html的页面,谈不上真正完全的交互,这里将和大家分享一下。
开始先把test.html的代码给大家分享一下:
<html> <head> <title>test</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <script type ="text/javascript" src ="test.js"></script> </head> <body> <form name="myform" onsubmit ="return false;"> <table> <tr> <td height ="30" width ="320" align="center" bgcolor="#DC143C">I'm Jack,I'm an IOS coder</td> </tr> <tr> <td height ="30" width ="320" align="center"> <input name ="input1" id ="input1" type="text" size="25" maxlength="100" > </td> </tr> <tr> <td height="30" width="60" align="center"> <input name ="submit" type="submit" value="submit" onClick ="check()"> </td> </tr> <tr> <td height="30" width="60" align="center"> <input name ="changevalue" type="submit" value="changevalue" onClick ="change_value()" > </td> </tr> <tr> <td height ="30" width ="320" align="center"> <input name ="input2" id ="input2" type="text" size="25" maxlength="100" > </td> </tr> </table> </form> </body></html>
其中有两个地方需要提醒大家一下,以免犯和我同样的错误哦
红线部分的onsubmit =”return false;”主要因为我用了button触发事件,submit默认刷新页面,所以要returnfalse来禁止触发事件后刷新页面。
红线部分,input的value和Onclick()函数的函数名字不能相同,要不然函数不能够被调用。
这两个地方都是自己不注意犯下的错误花了好长的时间又问了好几个人,最后才找到问题的所在。学的教训,大家一定要记得哦!!!
下面大家看下test.js文件的代码:
window.onerror = function(err) { log('window.onerror: ' + err);};function connectWebViewJavascriptBridge(callback) { if (window.WebViewJavascriptBridge) { callback(WebViewJavascriptBridge); } else { document.addEventListener('WebViewJavascriptBridgeReady', function() { callback(WebViewJavascriptBridge); }, false); }}function check(){ connectWebViewJavascriptBridge(function(bridge) { var str = document.getElementById('input1').value;//将第一个输入框的值传递到OC页面中去 bridge.callHandler('submit', str, function(response) { log('JS got response', response); }); });}function change_value(){ connectWebViewJavascriptBridge(function(bridge) { bridge.init(function(message, responseCallback) { log('JS got a message', message); var data = { 'Javascript Responds':'Wee!' }; log('JS responding with', data); responseCallback(data); }); bridge.registerHandler('changeValueHandler', function(data, responseCallback) { document.getElementById('input2').value ='3';//改变html页面上第二个输入框的值 var responseData = { 'Javascript Says':'Right back atcha!' } responseCallback(responseData) }); });}
不多说了demo下载地址
另外今天看到了一片博客对我的思路的启发很大也和大家分享下:
http://honglu.me/2014/09/27/WebViewJavascriptBridge使用/

HTML的未来趋势是语义化和Web组件,CSS的未来趋势是CSS-in-JS和CSSHoudini,JavaScript的未来趋势是WebAssembly和Serverless。1.HTML的语义化提高可访问性和SEO效果,Web组件提升开发效率但需注意浏览器兼容性。2.CSS-in-JS增强样式管理灵活性但可能增大文件体积,CSSHoudini允许直接操作CSS渲染。3.WebAssembly优化浏览器应用性能但学习曲线陡,Serverless简化开发但需优化冷启动问题。

HTML、CSS和JavaScript在Web开发中的作用分别是:1.HTML定义网页结构,2.CSS控制网页样式,3.JavaScript添加动态行为。它们共同构建了现代网站的框架、美观和交互性。

HTML的未来充满了无限可能。1)新功能和标准将包括更多的语义化标签和WebComponents的普及。2)网页设计趋势将继续向响应式和无障碍设计发展。3)性能优化将通过响应式图片加载和延迟加载技术提升用户体验。

HTML、CSS和JavaScript在网页开发中的角色分别是:HTML负责内容结构,CSS负责样式,JavaScript负责动态行为。1.HTML通过标签定义网页结构和内容,确保语义化。2.CSS通过选择器和属性控制网页样式,使其美观易读。3.JavaScript通过脚本控制网页行为,实现动态和交互功能。

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增强WebevebDevelopment。

HTML是构建网页结构的基石。1.HTML定义内容结构和语义,使用、、等标签。2.提供语义化标记,如、、等,提升SEO效果。3.通过标签实现用户交互,需注意表单验证。4.使用、等高级元素结合JavaScript实现动态效果。5.常见错误包括标签未闭合和属性值未加引号,需使用验证工具。6.优化策略包括减少HTTP请求、压缩HTML、使用语义化标签等。

HTML是一种用于构建网页的语言,通过标签和属性定义网页结构和内容。1)HTML通过标签组织文档结构,如、。2)浏览器解析HTML构建DOM并渲染网页。3)HTML5的新特性如、、增强了多媒体功能。4)常见错误包括标签未闭合和属性值未加引号。5)优化建议包括使用语义化标签和减少文件大小。

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境