转载请注明出处:王亟亟的大牛之路

最近都有事干然后,快到月底了这个月给CSDN的博文也就两篇,想想也蛮多天没更了,那就来一篇。

老规矩,先安利:https://github.com/ddwhan0123/Useful-Open-Source-Android (已经拆完了,基本可以根据链接找你的需要的东西给了,后期还会继续细分)

学了一段时间的RN,公司项目的部分模块也迁移到了RN。

我自己是会SE的东西却对JS不太熟,所以生产效率并不是太高,正好微信的小程序也是类似的实现,让我觉得掌握JS已经成了一个高优先级的学习任务了。

然后当下有2个学习方向其实我觉得还是可以自己去选择的,一个是 VUE 一个是 React.js

一个是阿里等大公司都推崇的:https://github.com/vuejs/vue,另一个看标题你就懂了:https://facebook.github.io/react/index.html


Hellow World

例子中可能出现在 RN文章里出现过的知识点,如果重复了,可以提出我再做修改。

下完所需的JS包简单的包分一下就能开工

官方的sample引用的是 react.js,react-dom.js和browser.min.js 这3个文件

这里补充一句,Browser.js是用来把JSX转成JS的,这个过程比较耗时,丢服务器就行,Demo是为了方便,你懂的

<head>里引用即可(记得设置下编码,不然中文就是乱码)

<head>
    <meta charset="UTF-8" />
    <script src="../build/react.js"></script>
    <script src="../build/react-dom.js"></script>
    <script src="../build/browser.min.js"></script>
  </head>

因为React.js的JSX语法和JS是不兼容的(别问为什么,我并不知道),要使用需要加一个<script>标签

<script type="text/babel">

然后在里面代码就行了!

变成都是从Hellow World开始的,我们也试着来一个。

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <script src="../build/react.js"></script>
    <script src="../build/react-dom.js"></script>
    <script src="../build/browser.min.js"></script>
  </head>
  <body>
    <div id="example"/>
    <script type="text/babel">

      var wjj = 'hellow world';
      ReactDOM.render(
        <div>{wjj}</div>,
        document.getElementById('example')
    );

    </script>
</body>
</html>

效果图:

在RN的时候也有类似的.render()方法,那么他到底是干什么的呢?

他就是把HTML 语言,并插入指定的 DOM 节点的,也就是插入了例子里叫’example’的那个 <div>节点


块级作用域和块变量

在java中并没有块变量或者块的概念,方法内的变量就是局部变量,类变量就是类变量。

然而在JS语法中有代码块的概念,也就是 { },白话的讲就是 在代码块内申明的变量的生命周期仅可用于代码块中。

而相对应的变量就是 let


let

let 和var类似 申明也是

{
let a = 10;
}

区别是 他只在他的代码块内有效,出了代码块就会 抛出ReferenceError: a is not defined

let不像var 必须先申明再使用,不然会也会抛出ReferenceError(本身JS的这种变量提升的行为,我就不太感冒,本来就应该先有蛋再有鸡)

既然 let和var只是有效范围不同,那let有什么用呢?

提供能好的代码逻辑,需要在块内有效的行为就只能在块内有效,省去了一车无用的”flag”变量


块级作用域

块级作用域{},他可以多层嵌套,像这样

{{{{
let a=123;
{let a="a";}
}}}};

他们是各自独立的,外层作用域无法读取内层作用域的变量,内层作用域可以定义外层作用域的同名变量,所以你申明一堆同名的变量也没有问题。

可以在块级作用域里使用申明函数,但是和let变量一样,出了块就无效了,像这样

{
      function f() {}
}

下一篇会介绍 const,props,PropTypes

混合开发的大趋势之 一个Android程序员眼中的 React.js 块级作用域 和 let的更多相关文章

  1. 混合开发的大趋势之 一个Android程序员眼中的 React.js 箭头函数,const, PropTypes

    转载请注明出处:王亟亟的大牛之路 昨天写了篇React.js的开头之作,讲了讲块级作用域和let,先安利:https://github.com/ddwhan0123/Useful-Open-Sourc ...

  2. 混合开发的大趋势之一React Native之简单的登录界面

    转载请注明出处:王亟亟的大牛之路 这些天都在学习RN这部分吧,然后写了个简单的登陆业务,从"实战"中讲解吧 还是继续安利:https://github.com/ddwhan0123 ...

  3. 混合开发的大趋势之一React Native与Android联调

    转载请注明出处:王亟亟的大牛之路 先安利,有空我都会更,看到的好东西都会放进来:https://github.com/ddwhan0123/Useful-Open-Source-Android 公司某 ...

  4. 混合开发的大趋势之一React Native手势行为那些事

    转载请注明出处:王亟亟的大牛之路 最近项目部分模块重构,事情有点多,学习进度有所延缓,外加一直在吸毒(wow你懂的),导致好多天没发问了,其实这部分知识月头就想写了,一直没补. 话不多说先安利:htt ...

  5. 混合开发的大趋势之一React Native之页面跳转(2)+物理返回+特定平台代码

    转载请注明出处:这里写链接内容 今天是10月份的最后一天,我加了3个月来的第一个班,挤出了这篇. 废话不多先安利,然后继续学习 RN 有好东西都往里面丢,努力做好归纳 https://github.c ...

  6. 混合开发的大趋势之一React Native之页面跳转

    转载请注明出处:王亟亟的大牛之路 最近事情有点多,没有长时间地连贯学习,文章也停了一个多礼拜,愧疚,有时间还是继续学习,继续写! 还是先安利:https://github.com/ddwhan0123 ...

  7. 混合开发的大趋势之一React Native之Image (脑动理解)

    文章是宝宝自己写的,你可以转走,标明哪来的就行王亟亟的大牛之路 国庆这些天要么旅游要么WOW,感觉整个人都废了.. 直接从黄种人晒成了非洲大酋长..然而还是无橙,这礼拜要做7天,昨天把单元测试的东西整 ...

  8. 金三银四背后,一个 Android 程序员的面试心得

    回顾一下自己这段时间的经历,九月份的时候,公司通知了裁员,我匆匆忙忙地出去面了几家,但最终都没有拿到offer,我感觉今年的寒冬有点冷.到十二月份,公司开始第二波裁员,我决定主动拿赔偿走人.后续的面试 ...

  9. 一个iOS程序员眼中的跨域问题

    摘要: 跨域问题是web开发领域一个常见的问题,相信每个web开发者都遇到"跨域"的问题 最近公司的iOS开发任务比较少,所以自己最近开始了Web开发的任务,在用H5做了很多页面, ...

随机推荐

  1. Spring Cloud Feign组件

    采用Spring Cloud微服务框架后,经常会涉及到服务间调用,服务间调用采用了Feign组件. 由于之前有使用dubbo经验.dubbo的负载均衡策略(轮训.最小连接数.随机轮训.加权轮训),du ...

  2. UNION ALL与UNION

    UNION 操作符用于合并两个或多个 SELECT 语句的结果集. 请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列.列也必须拥有相似的数据类型.同时,每条 SELECT 语句中的列 ...

  3. IO 之 File 类

    位于 java.io 包 用来将文件或者文件夹封装成对象 方便对文件和文件夹的属性信息进行操作 File 对象可以作为参数传递给流的构造函数 构造函数 // 可以将一个已存在的, 或者不存在的文件或者 ...

  4. 2015-03-22——js常用其它方法

    Function Function.prototype.method = function (name, func) {    this.prototype[name] = func;  //此时th ...

  5. 2015-03-18——mongodb的简单配置

    参考网址:http://www.cnblogs.com/mecity/archive/2011/06/11/2078527.html#3060056 mongod 数据库启动程序 mongo 数据库操 ...

  6. rest_framake之视图

    开始,先放大招 一  最原始的写法 前戏之序列化 class AuthorSerializer(serializers.ModelSerializer): class Meta: model = mo ...

  7. 前端(css引入的3中方式)

    一.css引入的三种方式 行间式 在标签头部的style属性内 属性值满足的是css语法 属性值用key:value形式赋值,value具有单位 属性值之间用;隔开 外联式(企业开发中使用这种方式) ...

  8. android学习四---Activity和Intent

    1.android项目资源深入了解 在深入学习android之前,先好好玩玩手机上的应用,大部分程序都有一个图标,点开图标,程序启动,一定时间后,程序会跳转到第一个界面,比如手机QQ,点开图标,会跳出 ...

  9. java架构师之路:推荐的15本书

    作为Java程序员来说,最痛苦的事情莫过于可以选择的范围太广,可以读的书太多,往往容易无所适从.我想就我自己读过的技术书籍中挑选出来一些,按照学习的先后顺序,推荐给大家,特别是那些想不断提高自己技术水 ...

  10. tf.clip_by_value:将tensor中的0和NONE进行范围限制的函数

    tf.clip_by_value clip_by_value(    t,    clip_value_min,    clip_value_max,    name=None) Defined in ...