tag 标签: 深入

相关博文
  • 热度 16
    2012-6-27 15:09
    1330 次阅读|
    0 个评论
        ·  基础RF2教学实验平台      物联网技术涉及非常广阔的新技术领域,涉及了当今世界网络通信,无线通信,嵌入式,单片机,模拟和数字电路,传感器技术,自动化技术等等新技术前沿领域。      无线龙提供了一整套物联网教学平台,其中基础RF教学平台主要为教学无线通信、嵌入式、传感器、无线网络、数据安全、无线定位、传感网等而设计,共为2个平台,分别为基础RF1与基础RF2。其中基础RF1针对的是所有学生,而基础RF2比较专业,主要针对的是物联网专业学生而设计的专业基础课程。      基础RF教学平台,为所有学生(特别是物联网专业学生)提供一整套完整的基础教学平台,为学生学习物联网专业知识打下坚实的基础。基础RF教学平台涉及物联网核心基础知识点包括:(无线)单片机与嵌入式基础、无线网络基础、传感器基础、无线定、信息安全、低功耗技术等等,为后续学习专业知识(传感网、无线个域网、ZigBee、低功耗Wi-Fi等)打下基础。     基础RF2教学平台提供单片机基础实验及ZigBee无线无线网络专业实验,其主要由2430无线单片机模块与液晶板来完成实验操作。  产品参数 ZigBee2430节点 (1) TI CC2540F128节点(增强型51内核); (2) 支持最新ZigBee2006协议栈; (3) 频率:2.4GHz,速率:250kbps; (4) Flash:128K (5) 最大输出功率0dBm,接收灵敏度-98dBm; (6) 支持星状,树状,网状网络;  (7) 支持大型网络 (8) 20Pin扩展,支持UART,SPI ZigBee2431节点 (1) TI CC2540F128节点(增强型51内核); (2) 支持最新ZigBee2006协议栈; (3) 频率:2.4GHz,速率:250kbps; (4) Flash:128K (5) 最大输出功率0dBm,接收灵敏度-98dBm; (6) 支持星状,树状,网状网络;  (7) 支持大型网络 (8) 20Pin扩展,支持UART,SPI (9) 拥有MOROROLA 物理定位引擎     
相关资源
  • 所需E币: 1
    时间: 2024-3-12 15:14
    大小: 1.14MB
    上传者: 月夜浅眠
    深入理解运放共模抑制比(上)
  • 所需E币: 0
    时间: 2024-3-12 15:12
    大小: 1.23MB
    上传者: 月夜浅眠
    深入理解运放共模抑制比
  • 所需E币: 0
    时间: 2024-3-1 10:24
    大小: 3.2KB
    上传者: 开心就很好了
    深入学习小程序框架底层原理,培养双线程思维——前端高手特训从0到1带你手写一个微信小程序底层框架!无论你是一位新手,还是一位有经验的开发者,能够自研一套小程序底层框架,都是你突破技术瓶颈有效途径。我将通过本篇文章带领大家从架构设计,原理剖析,再到源码的实现,一步步地实战构建一个完整的微信小程序底层框架,让大家深度掌握小程序双线程原理,助力大家具备把握最佳机会的能力和提升获取心仪Offer的成功率,成为一个真正有实力的技术人才!! 一、首先,我们先来认识小程序,那么什么是小程序呢?小程序是一种不需要下载安装即可使用的应用,它基于某个平台(如微信)运行,用户可以通过扫描二维码或搜索关键词来打开小程序。小程序的特点包括体积小、启动速度快、使用便捷,以及能够实现“用完即走”的理念,减少了用户安装应用的数量。小程序的开发通常采用前端技术,如HTML5、CSS3和JavaScript,并通过封装和提供丰富的API接口,实现与微信生态系统的高度整合。小程序可以提供各种服务,如游戏、购物、地图、社交和学习等,同时帮助商家展示产品、推广服务以及实现线上支付等功能。二、设计思路-渲染层小程序使用的是Exparser组件模型,Exparser组件模型与WebComponents中的shadowDOM高度相似,微信为什么使用自定义组件框架,而不使用WebComponents呢?主要还是出于安全考虑,并且方便管控。既然Exparser组件框架与shadowDOM高度相似,那么我们首先来了解一下shadowDOM。shadowDOM:WebComponents的一个重要属性是封装-可以将标记结构、样式和行为隐藏起来,并与页面上的其他代码相隔离,保证不同的部分不会混在一起,可使代码更加干净、整洁。其中,shadowDOM接口是关键所在,它可以将一个隐藏的,独立的DOM附加到一个元素上。三、Exparser组件模型Exparser组件模型参考了shadowDOM并进行了一些修改,像事件系统就是完全复刻的,slot插槽,属性传递等都基本一致。但同时它又具有一些特点:基于shadowDOM模型:模型上与WebComponents的shadowDOM高度相似,但不依赖浏览器的原生支持,也没有其他依赖库;实现时,还针对性地增加了其他API以支持小程序组件编程;可在纯JS环境中运行:这意味着逻辑层也具有一定的组件树组织能力;高效轻量:性能表现好,在组件实例极多的环境下表现尤其优异,同时代码尺寸也较小;四、逻辑层与视图层通信在小程序中,逻辑层只有一个,但是渲染层有多个,渲染层和逻辑层之间是通过微信客户端进行桥接通信的。那具体是怎么实现的呢?其实它使用的就是WeixinJSBridge通信机制。在小程序执行的过程中,微信客户端分别向渲染层和逻辑层注入WeixinJSBridge,WeixinJSBridge主要提供了以下几个方法:invoke:调用nativeAPI;invokeCallbackHandler:Native传递invoke方法回调结果;publish:渲染层用来向逻辑业务层发送消息,也就是说要调用逻辑层的事件方法;subscribe:订阅逻辑层消息;subscribeHandler:视图层和逻辑层消息订阅转发;setCustomPublishHandler:自定义消息转发;五、微信小程序主流框架有哪些?微信小程序是一种特殊的应用程序,它使用微信平台提供的JavaScript框架来构建。目前,微信小程序主要有以下三个主流框架:1、原生框架(VanillaFramework):原生框架是微信小程序的最基础、最原始的框架,它使用原生的JavaScript、WXML和WXSS来开发小程序。2、MiniprogramFramework(小程序框架):小程序框架是由微信团队提供的官方框架,用于简化小程序的开发过程。它提供了更高层次的抽象和封装,使得开发者可以更快速地构建小程序。3、mpvue:mpvue是一个基于Vue.js的小程序开发框架。它允许开发者使用Vue.js的语法和特性来开发小程序,从而降低了学习成本和提高了开发效率。六、小程序的底层实现原理主要涉及以下几个方面:框架架构:小程序框架通常采用前端框架,如微信小程序使用的是基于JavaScript的框架。这些框架提供了一套开发和运行环境,包括对视图层、逻辑层和数据层的管理和处理。渲染机制:小程序通过渲染引擎将开发者编写的代码转化为可视化界面。渲染引擎负责解析和处理小程序的标记语言,如HTML、XML等,并将其转换为浏览器可以显示的界面。数据通信:小程序需要与服务器进行数据通信,包括获取数据、上传数据等。通常使用HTTP协议进行网络请求,通过发送和接收数据来实现与服务器的交互。安全机制:为了保障用户数据的安全和隐私,小程序实现了一系列安全机制。例如,小程序在沙箱环境中运行,限制了对系统资源的访问权限;小程序代码签名和校验机制确保代码的完整性和安全性;同时,小程序还采用了数据加密、身份验证等措施来保护用户数据的传输和存储安全。跨平台适配:小程序需要在不同的操作系统和设备上运行,因此需要进行跨平台适配。框架会处理不同平台的差异,以确保小程序在不同设备上有一致的运行效果和用户体验。总的来说,小程序底层的实现原理是基于前端技术栈和相关技术,通过框架架构、渲染机制、数据通信、安全机制等来实现小程序的功能和特性。
  • 所需E币: 0
    时间: 2023-12-18 15:21
    大小: 3.45KB
    前端高手特训从0到1带你手写一个微信小程序底层框架,小程序是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或者搜一下即可打开应用。也体现了“用完即走”的理念,用户不用关心是否安装太多应用的问题。应用将无处不在,随时可用,但又无需安装卸载。框架管理了整个小程序的页面路由,可以做到页面间的无缝切换,并给以页面完整的生命周期。开发者需要做的只是将页面的数据、方法、生命周期函数注册到框架中,其他的一切复杂的操作都交由框架处理。wepy支持类似Vue的组件化开发,可以将页面拆分成多个独立的组件,提高代码复用性和开发效率。下面我们通过一个实际的案例来说明组件化开发在wepy中的应用。假设我们有一个小程序项目,其中包含一个商品列表页面和一个商品详情页面。我们可以将商品列表和商品详情抽象成两个组件,并在需要的地方引用它们。首先,我们创建一个名为GoodsList的组件。在src/components目录下创建GoodsList.wpy文件,并编写如下代码:importaxiosfrom'axios'constdefaultConfig={ timeout:5000, baseURL:'/release/'}constaxiosInstance=axios.create(defaultConfig)//添加请求拦截器axiosInstance.interceptors.request.use(config=>{ returnconfig},(err)=>{ //对请求错误做些什么 returnPromise.reject(err)})//请求拦截器,内部根据返回值,重新组装,统一管理。axiosInstance.interceptors.response.use(res=>{ console.log('接口详情:',res) returnres})exportdefault{ //封装get httpGet(url:any,params={}){  returnaxiosInstance.get(url,{params}).then(res=>res.data).catch() }, //封装post httpPost(url:any,params={}){  returnaxiosInstance.get(url,{params}).then(res=>res.data).catch() }}封装一个openStore(),使用indexedDB.open()方法返回一个IDBRequest对象,接着将这个对象上的三个事件分别放置进入:onsuccess、onerror、onupgradeneeded。onsuccess表示打开数据库成功的事件。onerror表示打开数据库失败的事件。onupgradeneeded是数据库升级事件,如果版本号更新,并且大于之前的版本号则进行数据库升级,该事件回调里面,会创建我们所需要的对象仓库,类似于关系型数据库中的表的概念。exportdefaultclassDB{ privatedbName:string//数据库名称 constructor(dbName:string){  this.dbName=dbName } //打开数据库 publicopenStore(storeName:string,keyPath:string,indexs?:Array<string>){  constrequest=window.indexedDB.open(this.dbName,2)  request.onsuccess=(event)=>{   console.log('数据库打开成功')   console.log(event)  }  request.onerror=(event)=>{   console.log('数据库打开失败')   console.log(event)  }  request.onupgradeneeded=(event)=>{   console.log('数据库升级成功')   const{result}:any=event.target   conststore=result.createObjectStore(storeName,{autoIncrement:true,keyPath})   if(indexs&&indexs.length>0){    indexs.map((v:string)=>{     store.createIndex(v,v,{unique:true})    })   }   store.transaction.oncomplete=(event:any)=>{    console.log('创建对象仓库成功')   }   console.log(event)  } }}在子组件headerCommon.vue中切换语言时,调用saveLanguageApi接口,保存当前语言环境到indexedDB中,并将当前语言包zhCn或者en作为参数传递给父组件App.vue,代码片段如下://commonHeader.vuefunctionhandleSelect(e:any){ if(e==='zh'){  emit('changeLang',zhCn)  saveLanguage('zh') }elseif(e==='en'){  emit('changeLang',en)  saveLanguage('en') } console.log(e)}//Mock接口:保存当前语言环境functionsaveLanguage(language:any){ saveLanguageApi(language).then(res=>{  const{success}=res  if(success){   console.log('保存当前语言包成功')  } })}通过调用getLanguage接口获取到之前调用存储在indexedDB中的语言环境,然后赋值给全局组件,代码片段如下://headerCommon.vue//Mock接口:保存当前语言环境functiongetLanguage(){ fetchLanguageApi().then(res=>{  const{success,result}=res  const{name}=result  if(success){   if(name==='zh'){    emit('changeLang',zhCn)   }elseif(name==='en'){    emit('changeLang',en)   }   console.log('获取当前语言环境成功')  } })}getLanguage()使用@include指令来引入定义好的样式函数,该函数的三个参数可以根据传入的值来对flex布局进行自定义,默认值为:column、center、right,在footerCommon.scss中我们重新自定义了该样式函数,分别传入row、space-between、flex-start,代码片段如下://footerCommon.scss.common-footer{  border-top:1pxsolidrgb(235,235,235); .footer{  @includemain-wrapper;  @includelayout(row,space-between,flex-start);  padding:20px0;  li{   @includelayout;   h4{    font-weight:bold;   }   a{    margin-bottom:10px;    color:rgb(72,72,72);    text-decoration:none;    &:hover{     text-decoration:underline;    }   }  } }}订单中心模块会使用到的两个Mock接口为saveOrderApi、fetchOrderApi,一个是立即预定,另一个是查询订单列表,具体代码片段如下//src/api/order/index.tsconststoreName=Object.keys(airbnb.orderObjectStore)[0]//Mock接口:立即预定exportasyncfunctionsaveOrderApi(params:any){ constloading=ElLoading.service({  lock:true,  background:'rgba(0,0,0,0.1)' }) //是否存在相同订单Id consthasOrderId=awaitnewPromise((resolve,reject)=>{  airbnb.airbnbDB.getList(storeName).then((res:any)=>{   setTimeout(()=>{    loading.close()   },200)   res&&res.filter((item:any)=>{    if(item.orderId===params.orderId){//存在相同订单Id     resolve(true)    }   })   resolve(false)  }) }) letresult:IResultOr if(hasOrderId){  result=awaitnewPromise((resolve,reject)=>{   resolve({code:'000001',success:false,message:'数据已存在',result:null})  }) }else{  result=awaitnewPromise((resolve,reject)=>{   airbnb.airbnbDB.updateItem(storeName,params).then(res=>{    setTimeout(()=>{     loading.close()    },200)    resolve({code:'000000',success:true,message:'操作成功',result:null})   })  }) } returnresult}通过应用这些进阶技巧和最佳实践,可以进一步提升小程序的性能和开发效率,同时优化代码质量,为用户提供更好的使用体验。
  • 所需E币: 1
    时间: 2023-6-13 10:15
    大小: 89.5KB
    上传者: 张红川
    对ATX电源控制电路的深入剖析.doc
  • 所需E币: 5
    时间: 2023-6-6 17:51
    大小: 11.22MB
    上传者: 木头1233
    深入了解ChatGPT.pdf深入了解ChatGPT.pdf
  • 所需E币: 1
    时间: 2023-5-12 10:42
    大小: 65.45MB
    深入PHP:面向对象、模式与实践(第5版)-(图灵程序设计丛书)-[英]MattZandstra
  • 所需E币: 1
    时间: 2023-5-9 14:33
    大小: 48.95MB
    深入理解MySQL主从原理-高鹏
  • 所需E币: 1
    时间: 2023-4-20 10:46
    大小: 130.39MB
    Oracle编程艺术:深入理解数据库体系结构(第3版)-(图灵程序设计丛书)-[美]ThomasKyte&DarlKuhn
  • 所需E币: 1
    时间: 2023-4-11 14:51
    大小: 83.45MB
    VC++深入详解-孙鑫-余安萍
  • 所需E币: 2
    时间: 2023-4-11 11:00
    大小: 13.13MB
    DebugHacks中文版-深入调试的技术和工具-吉岡弘隆-大和一洋-大岩尚宏-安部東洋-吉田俊輔-电子工业出版社
  • 所需E币: 1
    时间: 2023-4-11 09:46
    大小: 108.47MB
    Boost程序库完全开发指南-深入C++‘’准‘’标准库-罗剑锋
  • 所需E币: 5
    时间: 2023-3-5 23:10
    大小: 5.96MB
    上传者: 小圆梦
    从C到嵌入式C编程语言---入门实用深入
  • 所需E币: 0
    时间: 2023-2-12 18:24
    大小: 1.44MB
    上传者: ZHUANG
    信息技术与DSP技术与应用在线开放课程深入融合的改革与实践
  • 所需E币: 5
    时间: 2023-2-12 14:40
    大小: 2.38MB
    上传者: ZHUANG
    基于大数据背景的人工智能运用到计算机网络技术中的深入分析
  • 所需E币: 0
    时间: 2022-10-25 18:53
    大小: 18.44KB
    上传者: samewell
    Java深入源码级的面试题.docx
  • 所需E币: 4
    时间: 2022-10-11 12:49
    大小: 1.16MB
    上传者: czd886
    智能视频监控技术在智慧城市中的深入应用
  • 所需E币: 5
    时间: 2022-10-10 00:29
    大小: 7MB
    上传者: drillomt
    深入理解计算机系统_第三版【高清文字非扫描】带目录中文原版
  • 所需E币: 0
    时间: 2022-9-24 21:56
    大小: 2.24MB
    上传者: czd886
    物联网开启智能安防深入应用
  • 所需E币: 5
    时间: 2022-7-7 21:31
    大小: 140.62MB
    上传者: 西风瘦马
    深入理解云计算:基本原理和应用程序编程技术[(澳)Rajkumar.BuyyaChristian.Vccchiola(印)S.Thamarai.Selvi].pdf