- React——基础
贵沫末
react.js前端前端框架
文章目录React基础一、基础概念二、组件化三、状态四、属性五、项目初始化六、jsx七、创建React组件的两种方式函数式组件(推荐)类组件(不推荐)八、常用的hooks1、useState:用来修改状态值2、useReducer:用来修改状态值,比useState更适合处理复杂逻辑3、useContext:传递数据4、useMemo:缓存计算结果5、useCallback:缓存函数6、useEf
- React高级用法
react高级用法HOCHOC的实现方式1.属性代理(对传入组件属性上的一些操作)2.反向继承Hooks1.useState2.useEffect3.useLayoutEffect4.useRef5.useContext6.useReducer7.useMemouseCallback自定义hooksHOC含义:就是高阶组件,组件作为参数,返回的还是组件的函数特点:纯函数入参组件无法修改无副作用使用
- 【React】使用 useContext + useReducer 实现一个轻量的状态管理库
秀秀_heo
React及其周边生态react.jsjavascript前端
使用useContext+useReducer实现的轻量级状态管理,适合中小型React应用使用。实现思路使用createContext创建两个上下文:StateContext和DispatchContext。用useReducer管理状态逻辑。创建一个Provider组件包裹应用。提供两个hooks:useGlobalState()和useGlobalDispatch(),分别获取状态和派发方法
- 问:你是如何进行react状态管理方案选择的?
beifeng11996
reactjs
前言:最近接触到一种新的(对我个人而言)状态管理方式,它没有采用现有的开源库,如redux、mobx等,也没有使用传统的useContext,而是用useState+useEffect写了一个发布订阅者模式进行状态管理,这一点对我来说感觉比较新奇,以前从没接触过这种写法,于是决定研究一下目前比较常用的状态管理方式。ps:这里谈到的状态管理是指全局状态管理,局部的使用useState即可状态管理方式
- 详解React中的useContext
Async__小林_code
react.js前端javascript
使用useContext在React中管理去全局状态在React应用中,组件之间共享状态是一个常见的需求,useContext事故React提供的一个Hook,用于在函数组件中访问上下文(Context),它可以帮助我们在组件树中传递数据,而不需要手动通过每一层的props.什么是ContextContext提供了一种在组价之间共享值得的方式,而不必显式的通过组件树的每一层传递props,它通常用
- 如何在 React 中使用useContext Hook 实现一个全局主题切换功能,支持动态更新主题样式?
前端布洛芬
大白话前端八股react.js前端前端框架
大白话如何在React中使用useContextHook实现一个全局主题切换功能,支持动态更新主题样式?在前端开发的日常工作中,实现全局主题切换功能是一个高频需求。无论是打造个性化的博客网站,还是设计多样化界面的企业管理系统,都希望用户能根据自己的喜好切换主题风格,比如从明亮的白天模式切换到护眼的夜间模式。然而,在React项目里,当组件层级逐渐变深,要实现主题样式的全局动态更新,可不是一件容易的
- 项目实战--新闻分类
贩卖纯净水.
全球新闻发布系统项目javascriptreact.js开发语言
从antd中拿一个表格表格Table-AntDesignhttps://ant-design.antgroup.com/components/table-cn#table-demo-edit-cell使用的是可编辑单元格实现引入可编辑单元格:importReact,{useState,useEffect,useRef,useContext}from'react'import{Button,Tabl
- 1. 项目文件介绍
taozi-0610
react-dome前端typescriptreact
react-dome一、简介这是一个基于reacthook开发的前端页面二、用到的技术栈1.reacthook用途:ReactHooks是一种在函数组件中添加状态和其他React特性的方式。它们允许开发者在不编写类的情况下使用状态和其他React功能,从而简化了组件的编写过程。常用的Hooks包括useState(用于添加和管理状态)、useEffect(用于执行副作用操作)、useContext
- React Hook: 使用Context和useReducer代替Redux (Typescript)
月半叫做胖
React学习笔记前端学习日常开发typescripthooksreact
14.ReactHook:useContext+useReducer代替redux0.背景当组件嵌套很深,通过一直传参的方法来实现会非常麻烦,为了共享一些参数,一般可以通过Context来实现参数的托管,如果要对部分参数进行修改,可以通过redux或者mobx来做状态的集中管理。在有了Reacthooks之后,通过Context+useReducer完成Redux的功能,这里做一个简单的记录。1.
- 【JS】React Hooks 使用详解:从入门到精通的超详细教程
ChatGPT-千鑫
javascriptjavascriptreact.js开发语言
文章目录更多实用工具什么是ReactHooks?Hooks的三大规则为什么要使用Hooks?ReactHooks基础useState基本用法多个状态useEffect基本用法依赖项useContext基本用法高级ReactHooksuseReducer基本用法useCallback基本用法useMemo基本用法useRef基本用法自定义Hooks创建自定义Hook示例:使用窗口宽度自定义Hook使
- react中的useContext--为什么使用(一)
咖啡虫
Reactreact.js前端前端框架
React的数据传递流程在React中,数据传递通常是自上而下的,也就是父组件把数据通过props传递给子组件,子组件无法直接修改父组件的数据。例子:父组件向子组件传递数据constParent=()=>{constuser={name:"John",age:24};return;};constChild=({user})=>{return(姓名:{user.name}年龄:{user.age})
- 使用useReducer和useContext代替redux
思涵欧尼
每周一篇Js原理
本篇文章的受众为使用过redux,并且决定替换掉redux的人群,小白劝退哦一.useContext使用1.用途:传值,从父到子,孙,孙孙..都可以拿到值2.用法:在外面先定义Contextimport{createContext}from'react';constContext=createContext(null);exportdefaultContext;在最外层套上,这样全局都可以拿到值/
- 使用useReducer和useContext管理组件
蛮吉学长
转载学习react.jsjavascript前端
useReduceruseState可以用最简单的方式更新状态,但是状态更新的逻辑散落在UI中,不能独立复用,也不便于测试。使用useReducer来对一个组件的状态进行管理就可以避免这一情况。importReact,{useState,useReducer}from'react'constinitialState=[]constreducer=(state,action)=>{const[typ
- React 自定义 hooks实现自动上报 页面浏览量|点击事件
一个00后前端开发
前端框架react.js
通过自定义hooks,来控制监听DOM元素,分清楚依赖关系exportconstLogContext=createContext({});exportconstuseLog=()=>{/*定义一些公共参数*/constmessage=useContext(LogContext);constlistenDOM=useRef(null);/*分清依赖关系*/constreportMessage=use
- React Hook实现对话框组件
weixin_45703889
reactreact.jsjavascript前端css3css
ReactHook实现对话框组件准备思路:对话框组件是有需要的时候希望它能够弹出来,不需要的时候在页面上是没有任何显示的,这就意味着需要一个状态,在父组件点击按钮或其他的时候能够更改+它并显示,同时子组件(对话框组件)点击关闭的时候也需要更改这个状态。进阶:为对话框组件背景添加蒙皮,当对话框内容需要滚动时限制浏览器页面的滚动。ReactHook主要用到了useState,useContext,us
- Telegram miniApp开发(三)
无物勿吾
Telegramchrome前端
本节主要讲设置导航栏和监听事件导入依赖宝定义全局Context"useclient";import{createContext,useContext,useEffect,useMemo,useState}from"react";interfaceITelegramUser{id:number;first_name:string;last_name:string;username:string;la
- react useContext 用法
老胡说前端
react.js前端
1创建createContextimportReact,{useContext,useEffect,useState}from'react'constGlobalContext=React.createContext()2GlobalContext作为提供者exportdefaultfunctionApp(){const[filmList,setfilmList]=useState([]);con
- react的createContext及useContext 和 vue3的 provide 及 inject
Mosowe
vue3react依赖注入useContextprovide
这几个方法都是用于多层嵌套组件时,父组件向某个深层组件的传值,避免了props一层一层的传递。reactcreateContext和useContext新建context.ts文件:import{createContext}from'react'exportconstMyContext=createContext(null)父组件:import{MyContext}from'./context'i
- react 【七】各种hooks的使用/SPA的缺点
KIKIo_
reactreact.jsjavascript前端
文章目录1、Hook1.1为什么会出现hook1.2useState1.3useEffect1.4useContext1.5useReducer1.6useCallback1.7useMemo1.8useRef1.8.1ref绑定dom1.8.2ref解决闭包缺陷1.9useImperativeHandle1.10useLayoutEffect1.11自定义Hook1.11.1什么是自定义Hook
- 理解React hooks常用方法useState, useEffect, useMemo, useCallback, useContext
_双眸
前端react.jsjavascript
useStateuseState接收一个初始值,返回的是一个解构出来的数组,第一个是当前状态(似state),第二个是状态的更新函数(似setState),更新函数与react的setState不同的是,useState的更新函数会将状态替换(replace)而不是合并(merge)。使用场景:函数组件中需要用到状态值,类似react类组件的stateimportReact,{useState}f
- react中如何理解usestate、useEffect副作用、useRef标识和useContext
定位算法工程师
reactreact.jsjavascript前端
1.usestate1.1一般使用注意:useState的初始值(参数)只会在组件第一次渲染时生效。也就是说,以后的每次渲染,useState获取到都是最新的状态值,React组件会记住每次最新的状态值。其实与vue中的ref和reactive一样,通过useState获取到的数据可以实现组件视图实时交互,而普通定义的数据仅仅在业务中使用。使用规则:1.每个useState函数可以执行多次,每次执
- React Hooks:useState、useEffect和useContext
Windy_Coding
Reactreact.js
目录1.useState-让函数组件具有维持状态的能力1.1语法1.2应用2.useEffect-执行副作用2.1语法2.2应用2.3关于依赖项2.4小案例
- React开发必知必会的Hooks
Ying(英子)
reactreact.jsjavascript前端hookreacthookhooksuseState
文章目录前言1、React的组件创建方式2、什么是Hook?3、Hook总的使用规则一、useState二、useRef三、useEffect四、useLayoutEffect五、useReducer六、useContext七、memo与useMemo、useCallback1、memo2、useMemo3、useCallback4、三者区别八、useImperativeHandle前言Hooks
- React Hook 中 createContext & useContext 跨组件透传上下文与性能优化
大猫会长
前端react.jsjavascript
原文链接ReactHook中createContext&useContext跨组件透传上下文与性能优化-Postbird-猫既吾命本文是在:https://juejin.im/post/5ceb36dd51882530be7b1585的基础上进行的实践,非常建议阅读原文一、React.createContextAPI文...http://www.ptbird.cn/react-createCont
- React----Hooks函数组件----useContext
尤记昨日书
Reactreact.jsjavascript前端
一、定义useContext可以实现跨越组件层级,实现数据共享。二、实现原理使用createContext创建一个上下文对象,用useContext来接收这个对象,在.Provider包裹想要传递数组的所有组件,当组件上层最近的更新时,该Hook会触发重渲染,并使用最新传递的value值,以实现跨组件的数据传递。三、示例问题:现在有三个组件,,,,大概的关系是,1和2是兄弟组件,3是2的子组件,现
- react 多层级组件传值方案(React.context 和 useContext)
友人C君~
React
React中,数据流是自顶向下的,如果兄弟组件通信,那就得先状态提升到父组件但我们平时开发过程中,经常碰到组件树层级很深,如果不同层级的组件需要使用同一份数据,那从顶层组件分别传递props的方案肯定是很麻烦的而且太深的props层级对后续进行维护追溯数据源来说也是不好的一种解决方式因此context的使用场景就是:在组件树中,不同层级需要访问相同的数据源时,可以利用context,进行组件之间的
- React 组件跨层级数据共享:createContext、useContext、useMemo
真·skysys
大前端和跨平台技术react.jsjavascript前端
createContext问题背景:跨组件传值原本组件传递需要一层一层props传递,传递太过繁琐importReactfrom'react'functionNeedData(props){return{props.value2};<
- React Hooks 学习笔记
Programmer boy
react.js学习笔记
1.useState()实现对页面数据的存储,当数据改变时候,自动触发render函数2.useRef用来解决两个问题:1).是获取DOM元素或子组件的实例对象2).存储渲染周期之间共享的数据3.useEffect4.useLayoutEffect5.useReducer6.useContext7.useMemo性能优化8.useCallback性能优化9.useTransition性能优化10.
- React Hooks大全—useContext
CreatorRay
面试react前端react.js前端javascript
在本文中,我们将重点介绍useContext这个Hook,它可以让你在函数组件中轻松地访问ReactContext,从而实现跨组件的状态共享。我们将从基本使用,实现原理,最佳实践,以及一些常见的问题和解决方案来探讨useContext的用法和优势。我们还将给出一些必要的代码示例,帮助你更好地理解和应用useContext。基本使用公众号:Code程序人生,个人网站:https://creatorb
- react hooks的useContext
张滚滚QAQ
react.jsjavascript前端
简介:React的useContextHook用于在函数组件中获取上下文(Context)的值。它允许我们在组件中订阅并访问由React的ContextAPI提供的值。首先,我们需要创建一个上下文对象。上下文对象被创建时,它包含一个Provider和一个Consumer。在创建上下文对象后,我们可以使用useContextHook在函数组件中订阅上下文的值。以下是使用useContextHook的
- PHP,安卓,UI,java,linux视频教程合集
cocos2d-x小菜
javaUIlinuxPHPandroid
╔-----------------------------------╗┆
- zookeeper admin 笔记
braveCS
zookeeper
Required Software
1) JDK>=1.6
2)推荐使用ensemble的ZooKeeper(至少3台),并run on separate machines
3)在Yahoo!,zk配置在特定的RHEL boxes里,2个cpu,2G内存,80G硬盘
数据和日志目录
1)数据目录里的文件是zk节点的持久化备份,包括快照和事务日
- Spring配置多个连接池
easterfly
spring
项目中需要同时连接多个数据库的时候,如何才能在需要用到哪个数据库就连接哪个数据库呢?
Spring中有关于dataSource的配置:
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
&nb
- Mysql
171815164
mysql
例如,你想myuser使用mypassword从任何主机连接到mysql服务器的话。
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%'IDENTIFIED BY 'mypassword' WI
TH GRANT OPTION;
如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器,并使用mypassword作
- CommonDAO(公共/基础DAO)
g21121
DAO
好久没有更新博客了,最近一段时间工作比较忙,所以请见谅,无论你是爱看呢还是爱看呢还是爱看呢,总之或许对你有些帮助。
DAO(Data Access Object)是一个数据访问(顾名思义就是与数据库打交道)接口,DAO一般在业
- 直言有讳
永夜-极光
感悟随笔
1.转载地址:http://blog.csdn.net/jasonblog/article/details/10813313
精华:
“直言有讳”是阿里巴巴提倡的一种观念,而我在此之前并没有很深刻的认识。为什么呢?就好比是读书时候做阅读理解,我喜欢我自己的解读,并不喜欢老师给的意思。在这里也是。我自己坚持的原则是互相尊重,我觉得阿里巴巴很多价值观其实是基本的做人
- 安装CentOS 7 和Win 7后,Win7 引导丢失
随便小屋
centos
一般安装双系统的顺序是先装Win7,然后在安装CentOS,这样CentOS可以引导WIN 7启动。但安装CentOS7后,却找不到Win7 的引导,稍微修改一点东西即可。
一、首先具有root 的权限。
即进入Terminal后输入命令su,然后输入密码即可
二、利用vim编辑器打开/boot/grub2/grub.cfg文件进行修改
v
- Oracle备份与恢复案例
aijuans
oracle
Oracle备份与恢复案例
一. 理解什么是数据库恢复当我们使用一个数据库时,总希望数据库的内容是可靠的、正确的,但由于计算机系统的故障(硬件故障、软件故障、网络故障、进程故障和系统故障)影响数据库系统的操作,影响数据库中数据的正确性,甚至破坏数据库,使数据库中全部或部分数据丢失。因此当发生上述故障后,希望能重构这个完整的数据库,该处理称为数据库恢复。恢复过程大致可以分为复原(Restore)与
- JavaEE开源快速开发平台G4Studio v5.0发布
無為子
我非常高兴地宣布,今天我们最新的JavaEE开源快速开发平台G4Studio_V5.0版本已经正式发布。
访问G4Studio网站
http://www.g4it.org
2013-04-06 发布G4Studio_V5.0版本
功能新增
(1). 新增了调用Oracle存储过程返回游标,并将游标映射为Java List集合对象的标
- Oracle显示根据高考分数模拟录取
百合不是茶
PL/SQL编程oracle例子模拟高考录取学习交流
题目要求:
1,创建student表和result表
2,pl/sql对学生的成绩数据进行处理
3,处理的逻辑是根据每门专业课的最低分线和总分的最低分数线自动的将录取和落选
1,创建student表,和result表
学生信息表;
create table student(
student_id number primary key,--学生id
- 优秀的领导与差劲的领导
bijian1013
领导管理团队
责任
优秀的领导:优秀的领导总是对他所负责的项目担负起责任。如果项目不幸失败了,那么他知道该受责备的人是他自己,并且敢于承认错误。
差劲的领导:差劲的领导觉得这不是他的问题,因此他会想方设法证明是他的团队不行,或是将责任归咎于团队中他不喜欢的那几个成员身上。
努力工作
优秀的领导:团队领导应该是团队成员的榜样。至少,他应该与团队中的其他成员一样努力工作。这仅仅因为他
- js函数在浏览器下的兼容
Bill_chen
jquery浏览器IEDWRext
做前端开发的工程师,少不了要用FF进行测试,纯js函数在不同浏览器下,名称也可能不同。对于IE6和FF,取得下一结点的函数就不尽相同:
IE6:node.nextSibling,对于FF是不能识别的;
FF:node.nextElementSibling,对于IE是不能识别的;
兼容解决方式:var Div = node.nextSibl
- 【JVM四】老年代垃圾回收:吞吐量垃圾收集器(Throughput GC)
bit1129
垃圾回收
吞吐量与用户线程暂停时间
衡量垃圾回收算法优劣的指标有两个:
吞吐量越高,则算法越好
暂停时间越短,则算法越好
首先说明吞吐量和暂停时间的含义。
垃圾回收时,JVM会启动几个特定的GC线程来完成垃圾回收的任务,这些GC线程与应用的用户线程产生竞争关系,共同竞争处理器资源以及CPU的执行时间。GC线程不会对用户带来的任何价值,因此,好的GC应该占
- J2EE监听器和过滤器基础
白糖_
J2EE
Servlet程序由Servlet,Filter和Listener组成,其中监听器用来监听Servlet容器上下文。
监听器通常分三类:基于Servlet上下文的ServletContex监听,基于会话的HttpSession监听和基于请求的ServletRequest监听。
ServletContex监听器
ServletContex又叫application
- 博弈AngularJS讲义(16) - 提供者
boyitech
jsAngularJSapiAngularProvider
Angular框架提供了强大的依赖注入机制,这一切都是有注入器(injector)完成. 注入器会自动实例化服务组件和符合Angular API规则的特殊对象,例如控制器,指令,过滤器动画等。
那注入器怎么知道如何去创建这些特殊的对象呢? Angular提供了5种方式让注入器创建对象,其中最基础的方式就是提供者(provider), 其余四种方式(Value, Fac
- java-写一函数f(a,b),它带有两个字符串参数并返回一串字符,该字符串只包含在两个串中都有的并按照在a中的顺序。
bylijinnan
java
public class CommonSubSequence {
/**
* 题目:写一函数f(a,b),它带有两个字符串参数并返回一串字符,该字符串只包含在两个串中都有的并按照在a中的顺序。
* 写一个版本算法复杂度O(N^2)和一个O(N) 。
*
* O(N^2):对于a中的每个字符,遍历b中的每个字符,如果相同,则拷贝到新字符串中。
* O(
- sqlserver 2000 无法验证产品密钥
Chen.H
sqlwindowsSQL ServerMicrosoft
在 Service Pack 4 (SP 4), 是运行 Microsoft Windows Server 2003、 Microsoft Windows Storage Server 2003 或 Microsoft Windows 2000 服务器上您尝试安装 Microsoft SQL Server 2000 通过卷许可协议 (VLA) 媒体。 这样做, 收到以下错误信息CD KEY的 SQ
- [新概念武器]气象战争
comsci
气象战争的发动者必须是拥有发射深空航天器能力的国家或者组织....
原因如下:
地球上的气候变化和大气层中的云层涡旋场有密切的关系,而维持一个在大气层某个层次
- oracle 中 rollup、cube、grouping 使用详解
daizj
oraclegroupingrollupcube
oracle 中 rollup、cube、grouping 使用详解 -- 使用oracle 样例表演示 转自namesliu
-- 使用oracle 的样列库,演示 rollup, cube, grouping 的用法与使用场景
--- ROLLUP , 为了理解分组的成员数量,我增加了 分组的计数 COUNT(SAL)
- 技术资料汇总分享
Dead_knight
技术资料汇总 分享
本人汇总的技术资料,分享出来,希望对大家有用。
http://pan.baidu.com/s/1jGr56uE
资料主要包含:
Workflow->工作流相关理论、框架(OSWorkflow、JBPM、Activiti、fireflow...)
Security->java安全相关资料(SSL、SSO、SpringSecurity、Shiro、JAAS...)
Ser
- 初一下学期难记忆单词背诵第一课
dcj3sjt126com
englishword
could 能够
minute 分钟
Tuesday 星期二
February 二月
eighteenth 第十八
listen 听
careful 小心的,仔细的
short 短的
heavy 重的
empty 空的
certainly 当然
carry 携带;搬运
tape 磁带
basket 蓝子
bottle 瓶
juice 汁,果汁
head 头;头部
- 截取视图的图片, 然后分享出去
dcj3sjt126com
OSObjective-C
OS 7 has a new method that allows you to draw a view hierarchy into the current graphics context. This can be used to get an UIImage very fast.
I implemented a category method on UIView to get the vi
- MySql重置密码
fanxiaolong
MySql重置密码
方法一:
在my.ini的[mysqld]字段加入:
skip-grant-tables
重启mysql服务,这时的mysql不需要密码即可登录数据库
然后进入mysql
mysql>use mysql;
mysql>更新 user set password=password('新密码') WHERE User='root';
mysq
- Ehcache(03)——Ehcache中储存缓存的方式
234390216
ehcacheMemoryStoreDiskStore存储驱除策略
Ehcache中储存缓存的方式
目录
1 堆内存(MemoryStore)
1.1 指定可用内存
1.2 驱除策略
1.3 元素过期
2 &nbs
- spring mvc中的@propertysource
jackyrong
spring mvc
在spring mvc中,在配置文件中的东西,可以在java代码中通过注解进行读取了:
@PropertySource 在spring 3.1中开始引入
比如有配置文件
config.properties
mongodb.url=1.2.3.4
mongodb.db=hello
则代码中
@PropertySource(&
- 重学单例模式
lanqiu17
单例Singleton模式
最近在重新学习设计模式,感觉对模式理解更加深刻。觉得有必要记下来。
第一个学的就是单例模式,单例模式估计是最好理解的模式了。它的作用就是防止外部创建实例,保证只有一个实例。
单例模式的常用实现方式有两种,就人们熟知的饱汉式与饥汉式,具体就不多说了。这里说下其他的实现方式
静态内部类方式:
package test.pattern.singleton.statics;
publ
- .NET开源核心运行时,且行且珍惜
netcome
java.net开源
背景
2014年11月12日,ASP.NET之父、微软云计算与企业级产品工程部执行副总裁Scott Guthrie,在Connect全球开发者在线会议上宣布,微软将开源全部.NET核心运行时,并将.NET 扩展为可在 Linux 和 Mac OS 平台上运行。.NET核心运行时将基于MIT开源许可协议发布,其中将包括执行.NET代码所需的一切项目——CLR、JIT编译器、垃圾收集器(GC)和核心
- 使用oscahe缓存技术减少与数据库的频繁交互
Everyday都不同
Web高并发oscahe缓存
此前一直不知道缓存的具体实现,只知道是把数据存储在内存中,以便下次直接从内存中读取。对于缓存的使用也没有概念,觉得缓存技术是一个比较”神秘陌生“的领域。但最近要用到缓存技术,发现还是很有必要一探究竟的。
缓存技术使用背景:一般来说,对于web项目,如果我们要什么数据直接jdbc查库好了,但是在遇到高并发的情形下,不可能每一次都是去查数据库,因为这样在高并发的情形下显得不太合理——
- Spring+Mybatis 手动控制事务
toknowme
mybatis
@Override
public boolean testDelete(String jobCode) throws Exception {
boolean flag = false;
&nbs
- 菜鸟级的android程序员面试时候需要掌握的知识点
xp9802
android
熟悉Android开发架构和API调用
掌握APP适应不同型号手机屏幕开发技巧
熟悉Android下的数据存储
熟练Android Debug Bridge Tool
熟练Eclipse/ADT及相关工具
熟悉Android框架原理及Activity生命周期
熟练进行Android UI布局
熟练使用SQLite数据库;
熟悉Android下网络通信机制,S