CAllBACk ( 回调函数 ) --》 编程思想 理解

你去调用系统的函数,是直调。让系统调用你的函数,就是回调。

https://www.zhihu.com/question/19801131

所谓的回调函数就是所谓的委托

事件的原理就是委托

回调函数在什么场景有用?
我要在特定时候执行一个任务,至于是什么时候我自己都不知道。比如某一时间到了或者某一事件发生或者某一中断触发。


回调函数怎么起作用?
把我要执行的这个任务写成一个函数,将这个函数和某一时间或者事件或者中断建立关联。当这个关联完成的时候,这个函数华丽的从普通函数变身成为回调函数。


回调函数什么时候执行?
当该回调函数关心的那个时间或者事件或者中断触发的时候,回调函数将被执行。
一般是触发这个时间、事件或中断的程序主体(通常是个函数或者对象)观察到有一个关注这个东东的回调函数的时候,这个主体负责调用这个回调函数。


回调函数有什么好处?
最大的好处是你的程序变成异步了。也就是你不必再调用这个函数的时候一直等待这个时间的到达、事件的发生或中断的发生(万一一直不发生,你的程序会怎么样?)。再此期间你可以做做别的事情,或者四处逛逛。当回调函数被执行时,你的程序重新得到执行的机会,此时你可以继续做必要的事情了。



import DeviceInfo from 'react-native-device-info';
import * as Config from '../Common/Config';
var RNFS = require('react-native-fs');

const dirName = Config.APP_Course_New;
let index = Config.APP_Course_New.lastIndexOf('/');
if (index !== -1)
{
    dirName = dirName.substring(index+1);
}
index = dirName.lastIndexOf(".");
dirName = dirName.substring(0,index);

function AppDatas(){

};

AppDatas.prototype.modeChoice = {
    // 上课 1
    // 备课 2
    modeChoice              : 1,
 };


AppDatas.prototype.selectCourse = {
    Course_Type_Id              : 1,
    Course_Type_Name            : "",
    Course_Id                   : 1,
    Course_Name             : "",
    Class_Time                  : "",
    Class_Name                  : "",
};

AppDatas.prototype.courseUpdate = {
    newCourseDestNameTmp        :RNFS.CachesDirectoryPath+"/"+DeviceInfo.getVersion()+'.'+Config.APP_CLIENT_RES_VERSION+"/"+"test.zip",
    newCourseDestDirTmp         :RNFS.CachesDirectoryPath+"/"+DeviceInfo.getVersion()+'.'+Config.APP_CLIENT_RES_VERSION,
    newCourseDestDir            :RNFS.CachesDirectoryPath+"/"+DeviceInfo.getVersion()+'.'+Config.APP_CLIENT_RES_VERSION+"/"+dirName,
    updateCourseYes             :true,
    newCourseDestName           :RNFS.MainBundlePath+"/lesson/test2.ly",
};

var instance = new AppDatas();
module.exports = instance;


        if (result.status  === 0 ) {
          console.log('课件有更新 。。文件从 缓存打开');
          AppDatas.courseUpdate.updateCourseYes = true;
          AppDatas.courseUpdate.newCourseDestDir = AppDatas.courseUpdate.newCourseDestDir;
          console.log('AppDatas.courseUpdate.newCourseDestDir 从缓存打开');
          this.setState({courseUpdate :true});
        }
        else
        {
          console.log('课件  没有  更新 。。文件从 app 打开');
          AppDatas.courseUpdate.updateCourseYes = false;
          AppDatas.courseUpdate.newCourseDestDir = RNFS.MainBundlePath+"/lesson";
          console.log('AppDatas.courseUpdate.newCourseDestDir 从app打开');
          this.setState({courseUpdate :false});
        }

'use strict';

import React, { Component } from 'react';
import {
  NavigatorIOS,
  Image,
  Text,
  TouchableHighlight, 
  StyleSheet,
  View,
  Alert,
  ListView,
  TouchableOpacity,
  NativeModules,
  InteractionManager,
} from 'react-native';

var LessonParserModule = NativeModules.RNLessonParserModule;
import {toastShort} from './ToastUtil';
import AppDatas from  '../AppDatas/AppDatas';
var RNFS = require('react-native-fs');

class OpenCourse  {

    openCourse( filename, callback )
    {
        LessonParserModule.OpenLesson(filename, (ret)=>{
            callback(ret);
        });
    }

}


var instance = new OpenCourse();

module.exports = instance;



        console.log('打开的课件名字  需要 通过计算得出  ');
        let courseLastName = "";
        if (AppDatas.courseUpdate.updateCourseYes) {
          courseLastName = "/test1.ly";
        }
        else
        {
          courseLastName = "/test2.ly";
        }
        AppDatas.courseUpdate.newCourseDestName = AppDatas.courseUpdate.newCourseDestDir+courseLastName;

        function  switchPage( ret )
        {
          if ( ret === 1 )
          {
            navigator.push({name:'CoursaDetailPage', params:{lesson:'test2'}, component:CoursaDetailPage});
          }
          else
          {
            toastShort("catalogpage open file fail");
          }
        }

        OpenCourse.openCourse(AppDatas.courseUpdate.newCourseDestName, switchPage );




最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容