首页
学习
活动
专区
圈层
工具
发布

给在本机运行的 React 程序配置 HTTPS

如果用 create-react-app 构建一个程序,并且在本地运行,默认情况下会用 HTTP 协议为该程序提供服务。而在生产环境中运行的程序都用 HTTPS 进行服务。...我们都知道,create-react-app 程序是用 npm run start(或简称为 npm start)运行的,在 package.json 文件的 scripts 部分中,有这样一行配置:...❝注意:以下命令是在 macOS 上执行的,Linux 下可以用相同的方式操作。但是不保证在 Windows 下也能成功。...❞ 在项目根目录中运行: openssl req -x509 -newkey rsa:2048 -keyout keytmp.pem -out cert.pem -days 365 然后运行: openssl...然后双击证书安装,设置为“受信任的证书或签发机构”。 设置完成后,就可以通过 HTTPS 在本地访问自己的 React 程序了: ?

3.7K20

关于React Native项目在android上UI性能调试实践

不过有些时候,你还是可以想办法提升应用的性能(有的时候问题根本不是出在原生代码上!) 要想解决应用的性能问题,第一步就是搞明白在每个16毫秒的帧中,时间都去哪儿了。...被调试的代码段在开始和结束处加上标记,在执行的过程中标记会被记录,最后会以图表形式展现统计结果。包括Android SDK自己和React Native框架都已经提供了标准的标记供你查看。...在收集结束后,systrace会给你提供一个链接,你可以在浏览器中打开这个链接来查看数据收集的结果。 查看性能数据 在浏览器中打开数据页面(建议使用Chrome),你应该能看到类似这样的结果: ?...注意在上图中JS线程基本上一直在执行,并且超越了帧的边界。这个应用就没法以60FPS渲染了。在这种情况下,问题出在JS中。 你还有可能会看到一些类似这样的东西: ?...原生UI问题 如果你发现问题出在原生UI上,有两种常见的情况: 你每帧在渲染的UI给GPU带来了太重的负载,或者: 你在动画、交互的过程中不断创建新的UI对象(譬如在scroll的过程中加载新的内容)

3.7K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    AspectJ在android上的开发

    Android上运用AOP的思想开发,可以快速的帮助我们简化在横向开发中的重复性工作,简单的说就是把涉及到众多模块的某一类问题进行统一管理比如:性能检测、日志打印手机等。...AspectJ实际上是对AOP编程思想的一个实践,当然,除了AspectJ以外,还有很多其它的AOP实现,例如ASMDex、javassist等,但目前最好、最方便的,依然是AspectJ。...直接贴例子 引入插件,这边是添加在app.gradle, 不是添加在项目的gradle中 import org.aspectj.bridge.IMessage import org.aspectj.bridge.MessageHandler...final def variants = project.android.applicationVariants //在全局变量中配置编译项以及,对应的log输出 variants.all { variant.../Android-AOPExample 熟悉了一遍 补充:Android-AOPExample的例子下载下来,在gradle版本再2.3.0及其以上的版本编译会出现问题 报错误:No such property

    2.1K20

    eBPF在android上的使用

    对于eBPF可以简单的理解成kernel实现了一个虚拟机机制,将类C代码编译成字节码(后文有详细解释),挂在到内核的钩子上,当钩子被触发时,kernel在虚拟机的"沙盒"中运行字节码,这样既能方便的实现很多功能...BCC在android系统上也可以运行,但是要对系统进行一定程度的修改,后续可能会写单独的文章进行讲解。对于内核开发者我还比较关注怎么自己来实现监控的功能,下文也将做简单的讲解。 ?...1. android系统对eBPF的编译支持 目前android编译系统已经对eBPF进行了集成,通过android.bp就能很方便的在android源代码中编译eBPF的字节码。...返回值必须是android::netdutils::status::ok(在android的新版本中已经进行修改)。 5....至此,如何在android平台使用eBPF实现统计系统中每个pid在一段时间内系统调用的次数的功能就介绍完了。

    5.9K10

    ProGuard 在 Android 上的使用姿势

    如果以上还不足以说服您使用 ProGuard,其实移除无用代码和混淆所有名称还有其他更多的优化效果: 在一些版本的 Android 设备上,DEX 代码会在安装或者运行时被编译成机器码。...这些警告的一个原因就是,您的构建路径中没有加入需要依赖的 JARs,如使用了 provided (仅编译时)依赖。而有时候,在 Android 上这些代码的依赖在运行时并不会被真正的调用。...在某些情况下,ProGuard 的警告确实有助于您发现闪退的罪魁祸首和关于您配置上的其他问题。...有些项目简单地在他们的文档或者 README 上提及了必要的混淆规则,所以您需要复制粘贴这些规则到您的主 ProGuard 配置文件中。...tools 目录下(SDK/tools/proguard/proguard-android.txt),但在新版的 SDK Tools 和 Android Gradle 插件版本2.2.0+上,可以在构建时从

    3.8K40

    React中,在styled-components基础上使用iconfont字体图标

    styled-components官网 巧妇难为无米之炊,先准备米: 从iconfont官网选取图标 添加购物车 在购物车添加项目 项目中生成代码 下载代码包到本地 这套流程应该娴熟到不用看上边的文案...重点来了, 怎么在style-components中使用iconfont: 提取下载的字体文件到项目的src>assets>fonts文件夹中(当然可以根据你的项目决定其他的路径) ?...提取iconfont.css代码到全局style.js文件中的GlobalStyled的createGlobalStyle``中,用于全局通用。...t=1583658254672') format('truetype'), /* chrome, firefox, opera, Safari, Android, iOS 4.2+ */ 21...="iconfont icon-sousuo" /> 源代码路径:https://github.com/xingorg1/JuFengGuo/blob/master/advanceCourse/react

    4.4K30

    MobX 在 React Native开发中的应用

    MobX 是一款精准的状态管理工具库,如果你在 React 和 React Native 应用中使用过 Flux、Alt、Redux 和 Reflux,那毫不犹豫地说,MobX 的简单性将成为你状态管理的不二之选...这是我们要增加新条目时转向的组件; 在 addListItem中,把 this.state.text 传入this.props.store.addListItem。...在与输入框绑定的 updateText 中会更新this.state.text; 在 removeListItem 中调用 this.props.store.removeListItem 并传入条目;...在 addItemToList 中调用 this.props.navigator.push,传入条目和数组存储两个参数; 在 render 方法中,通过属性解构数据存储: const { list }...= this.props.store 8.在 render 方法中,也创建了界面,并绑定了类的方法 import React, { Component } from 'react' import { View

    14.2K70

    在React Native中优雅的使用iconfont

    React Native中的iconfont 关于在React Native中使用iconfont,网上已有很多非常好的解决方案,用的最多的就是react-native-vector-icons , 这个库支持很多常用的...IconFont的使用原理 其实IconFont就是一些文字,通过在web上的使用,我们可以大概猜出使用方法: 指定字体集 把对应的16进制码当成文字写到文本中 在React Native中同样如此,我们可以通过...实际上,一个字体通常由数个表(table)构成,字体的信息存储在表中。...,需要引入字体文件: Android: 把字体文件拷贝到[project root]/android/app/src/main/assets/fonts/ iOS: 把字体文件拖到对应的Xcode工程里面...iOS上添加字体文件具体的流程可以参考https://github.com/oblador/react-native-vector-icons#option-manually。

    18.2K40

    MobX 在 React Native开发中的应用

    MobX 是一款精准的状态管理工具库,如果你在 React 和 React Native 应用中使用过 Flux、Alt、Redux 和 Reflux,那毫不犹豫地说,MobX 的简单性将成为你状态管理的不二之选...这是我们要增加新条目时转向的组件; 在 addListItem中,把 this.state.text 传入this.props.store.addListItem。...在与输入框绑定的 updateText 中会更新this.state.text; 在 removeListItem 中调用 this.props.store.removeListItem 并传入条目;...在 addItemToList 中调用 this.props.navigator.push,传入条目和数组存储两个参数; 在 render 方法中,通过属性解构数据存储: const { list }...= this.props.store 8.在 render 方法中,也创建了界面,并绑定了类的方法 import React, { Component } from 'react' import

    14.5K80

    页面结构化在 Android 上的尝试

    下面讲讲Lego在Android上一次小小尝试 一,MVP简介 ? MVC太过常见这里不啰嗦。实际应用MVC当中,Activity占据打部分的工作,View和Controller的身份分不清。...先来看看MVP模式的核心思想:View不直接与Model交互 MVP 把 Activity 中的 UI 逻辑抽象成 View 接口,把业务逻辑抽象成 Presenter 接口,Model 类还是原来的...Model 在MVP设计模式中, View:由Activity充当,并且响应生命周期 Model:还是原来的数据层,网络,缓存,解析等。...不然抽这么多接口干嘛 模块职责明确,层次清晰 Presenter可复用(在日迹的需求中,首页和4Tab公用一个Presnter) 方便单元测试 避免Activity内存泄露, Acitvity一身轻松...这玩意不好理解,需要实战中理解。 在手Q项目里,MVP会激增很多方法数。 ? 三,Lego页面结构化 前面铺垫这么多,终于到我要吹水的时候了。

    1.5K50

    页面结构化在Android上的尝试

    下面讲讲Lego在Android上一次小小尝试 一,MVP简介 ? MVC太过常见这里不啰嗦。实际应用MVC当中,Activity占据打部分的工作,View和Controller的身份分不清。...先来看看MVP模式的核心思想:View不直接与Model交互 MVP 把 Activity 中的 UI 逻辑抽象成 View 接口,把业务逻辑抽象成 Presenter 接口,Model 类还是原来的...Model 在MVP设计模式中, View:由Activity充当,并且响应生命周期 Model:还是原来的数据层,网络,缓存,解析等。...解耦,绝对的。不然抽这么多接口干嘛 2. 模块职责明确,层次清晰 3. Presenter可复用(在日迹的需求中,首页和4Tab公用一个Presnter) 4. 方便单元测试 5....三,Lego页面结构化 前面铺垫这么多,终于到我要吹水的时候了。MVC,MVP,还有MVVM等MVX系列的设计模式,都是一种大而全的统一管理。在项目结构中最为关键其实是:分模块! ?

    1.7K60

    如何正确的在 Android 上使用协程 ?

    第一类是 Medium 上热门文章的翻译,其实我也翻译过: 在 Android 上使用协程(一):Getting The Background 在 Android 上使用协程(二):Getting started...在 Android 上使用协程(三) :Real Work 说实话,这三篇文章的确加深了我对协程的理解。...在 Android 中,一般是不建议直接使用 GlobalScope 的。那么,在 Android 中应该如何正确使用协程呢?再细分一点,如何直接在 Activity 中使用呢?...协程在 Android 上的使用 GlobalScope 在一般的应用场景下,我们都希望可以异步进行耗时任务,比如网络请求,数据处理等等。当我们离开当前页面的时候,也希望可以取消正在进行的异步任务。...总结 以上简单的介绍了在 Android 中合理使用协程的一些方案,示例代码已上传至 Github。

    4.4K30
    领券