APP-移動(dòng)動(dòng)態(tài)化方案在蜂鳥的架構(gòu)演進(jìn)(含React Native與Weex對(duì)比)

最近在準(zhǔn)備學(xué)習(xí)一門跨平臺(tái)語言時(shí)候表示很糾結(jié)再姑,學(xué)習(xí)一門語言時(shí)間緊迫, 必須學(xué)到有用又適應(yīng)市場(chǎng)的一門語言

直到看到這篇文章后就恍然大悟了亚情,剛好餓了么也是一路采坑過來的歉闰,必須借鑒學(xué)習(xí)一下,說明最值得學(xué)習(xí)的還是阿里系Weex琢唾,體驗(yàn)什么的也比RN要好不少

當(dāng)下载荔,移動(dòng)動(dòng)態(tài)化已經(jīng)成為各大公司都回避不了的問題,產(chǎn)品的快速迭代對(duì)技術(shù)提出了更高的要求采桃,而移動(dòng)端的動(dòng)態(tài)化方案也是層出不窮:Hypid懒熙、結(jié)構(gòu)化 Native View、React Native普办、Weex工扎,什么樣的方案才是適合自己團(tuán)隊(duì)的呢?本文將分享餓了么蜂鳥團(tuán)隊(duì)在過去兩年多業(yè)務(wù)快速增長(zhǎng)過程中衔蹲,移動(dòng)動(dòng)態(tài)化方面的實(shí)踐和探索肢娘。

什么是移動(dòng)動(dòng)態(tài)化?

移動(dòng)指的是移動(dòng)端舆驶,包括安卓橱健、iOS。動(dòng)態(tài)化則是動(dòng)態(tài)部署和邏輯下發(fā)到客戶端的能力沙廉。移動(dòng)動(dòng)態(tài)最好的狀態(tài)就是讓移動(dòng)應(yīng)用和 Web 一樣畴博,想發(fā)就發(fā)!

為什么移動(dòng)端要強(qiáng)調(diào)動(dòng)態(tài)化的能力蓝仲?

原因有如下三大點(diǎn):

業(yè)務(wù)迭代太快俱病。當(dāng)下大部分團(tuán)隊(duì)都是敏捷開發(fā)的模式官疲,即使兩周做一次迭代,產(chǎn)品周期還是會(huì)覺得長(zhǎng)亮隙,有些應(yīng)用不能及時(shí)上線途凫。

應(yīng)用市場(chǎng)審核慢。安卓基本當(dāng)天發(fā)應(yīng)用市場(chǎng)溢吻,當(dāng)天就能夠有更新维费。但 iOS 需要約 3-4 天來審核。假設(shè)有些功能需要定時(shí)上線促王,iOS 審核時(shí)間必須要考慮進(jìn)去犀盟。

用戶升級(jí)周期長(zhǎng)。統(tǒng)計(jì)表明蝇狼,每一個(gè)安卓版本發(fā)布阅畴,一周內(nèi)會(huì)有 70% 的用戶更新,一個(gè)月其余用戶才能陸續(xù)完成更新迅耘。

移動(dòng)動(dòng)態(tài)化方案共性贱枣,有如下三點(diǎn):

跨平臺(tái)。

布局颤专。約定 DSL纽哥,保證渲染性能。

邏輯栖秕。Android 和 iOS 必須共用解釋器春塌。

蜂鳥團(tuán)隊(duì)的現(xiàn)狀與業(yè)務(wù)特點(diǎn)

蜂鳥團(tuán)隊(duì)現(xiàn)狀

蜂鳥團(tuán)隊(duì)于 2014 年成立,初衷是為了承接餓了么的物流業(yè)務(wù)簇捍。隨著時(shí)間推移只壳,訂單量從每日幾千單到百萬單,配速員也達(dá)到百萬數(shù)量垦写,服務(wù)品類涉及外賣吕世、商超、鮮花梯投、蛋糕命辖、文件等,蜂鳥提供全時(shí)段配送分蓖,配送服務(wù)覆蓋全國(guó) 1200 多個(gè)城市尔艇。

蜂鳥團(tuán)隊(duì)的業(yè)務(wù)特點(diǎn)

蜂鳥團(tuán)隊(duì)的業(yè)務(wù)主要有離散性和突發(fā)性兩大特點(diǎn),如下圖:

[圖片上傳中...(image-bdf201-1522679509307-23)]

從業(yè)務(wù)曲線可以看到兩個(gè)很明顯的波峰么鹤,這是午终娃、晚用餐時(shí)間。同時(shí)蒸甜,如果運(yùn)營(yíng)方面配置一些活動(dòng)棠耕,會(huì)導(dǎo)致這兩個(gè)波峰徒增余佛。所以,動(dòng)態(tài)方案要想把這兩個(gè)時(shí)間段服務(wù)好窍荧,必須要考慮流量陡增下的性能壓力辉巡。

蜂鳥團(tuán)隊(duì)的技術(shù)特點(diǎn)和挑戰(zhàn)

蜂鳥團(tuán)隊(duì)的技術(shù)特點(diǎn)和挑戰(zhàn),我主要分享重度依賴蕊退、網(wǎng)絡(luò)環(huán)境復(fù)雜郊楣、重度使用和 28 定律這四個(gè)方面。

重度依賴

當(dāng)前蜂鳥有眾包瓤荔、團(tuán)隊(duì)和送送三部分業(yè)務(wù)净蚤,右側(cè)是一些功能展示,如下圖:

[圖片上傳中...(image-a9c71a-1522679509305-22)]

這樣的工具型應(yīng)用输硝,需要對(duì) APP 有更強(qiáng)的控制今瀑、監(jiān)控等能力。必要時(shí)還要做到強(qiáng)制更新腔丧。

對(duì)應(yīng)到動(dòng)態(tài)方案的話放椰,控制能力就需要?jiǎng)討B(tài)方案必須具備動(dòng)態(tài)降級(jí)的能力作烟、監(jiān)控能力愉粤,實(shí)時(shí)的性能監(jiān)控和業(yè)務(wù)埋點(diǎn)監(jiān)控。強(qiáng)制更新方面拿撩,動(dòng)態(tài)方案必須做到用戶無感知的熱更新衣厘。

網(wǎng)絡(luò)環(huán)境復(fù)雜

餓了么小哥,每天穿梭在大街小巷压恒、地下商超影暴,他們的網(wǎng)絡(luò)環(huán)境非常不穩(wěn)定。據(jù)統(tǒng)計(jì)探赫,有近 25% 的用戶請(qǐng)求還來自非 4G 環(huán)境型宙。

整體來說的網(wǎng)絡(luò)環(huán)境復(fù)雜、信號(hào)差和 DNS 污染伦吠,那么動(dòng)態(tài)方案就要解決 DNS 攔截妆兑、弱網(wǎng)環(huán)境下資源下發(fā)等問題。

重度使用

無論是下雨毛仪、下雪搁嗓,還是發(fā)洪水大家都會(huì)叫餓了么。

配送員在高峰期的運(yùn)動(dòng)曲線箱靴,如下圖:

面對(duì)這樣爭(zhēng)分奪秒的準(zhǔn)時(shí)達(dá)壓力腺逛,如果動(dòng)態(tài)方案不給力,會(huì)導(dǎo)致應(yīng)用出現(xiàn)崩潰或卡頓衡怀,騎手必定不會(huì)有好的體驗(yàn)棍矛,甚至影響送餐時(shí)間安疗。所以我們的動(dòng)態(tài)方案一定要保證性能和穩(wěn)定性。

28定律

相信很多公司的應(yīng)用都符合類似 28 定律够委,蜂鳥也不例外茂契。

如下圖,蜂鳥的 28 定律:

可以從圖中看出慨绳,大部分騎手日常使用的主流層面掉冶,可以采用 Native 來開發(fā),這部分重度使用的占比約 20%脐雪,其余 80% 的功能都可以考慮動(dòng)態(tài)化方案(H5)厌小。

蜂鳥團(tuán)隊(duì)的動(dòng)態(tài)化架構(gòu)演進(jìn)

蜂鳥的動(dòng)態(tài)方案經(jīng)過 Hypid、React Native 和 Weex 三個(gè)主要階段战秋。

第一階段:Hypid

在 Hypid 方案上璧亚,以 H5 的動(dòng)態(tài)性為基礎(chǔ),通過 Jspidge 做橋梁脂信,與 Native 進(jìn)行通信癣蟋,之后通過 URL Router 進(jìn)行跳轉(zhuǎn),架構(gòu)如下圖:

這套動(dòng)態(tài)方案的優(yōu)點(diǎn)顯而易見狰闪,這里主要介紹開發(fā)效率疯搅、更新體驗(yàn)和跨平臺(tái)三方面:

開發(fā)效率。Web 經(jīng)過多年的應(yīng)用實(shí)踐埋泵,已經(jīng)擁有完整的開發(fā)流程和開發(fā)工具幔欧,開發(fā)一個(gè) H5 頁面非常快速丽声。開發(fā)效率這一因素不能忽略礁蔗,因?yàn)槌跗诋a(chǎn)品的想法和落地速度會(huì)直接影響產(chǎn)品的命運(yùn)。

如蜂鳥送送雁社,初期沒有原生的資源去支撐浴井,就用原生包殼,內(nèi)部全部用 H5霉撵,這樣的情況堅(jiān)持了兩月左右磺浙,為蜂鳥送送前期的方案驗(yàn)證做了很大的貢獻(xiàn)。

更新體驗(yàn)喊巍。因 H5 和原生耦合只有擴(kuò)展的 Native API屠缭,只要把這些 API 維護(hù)足夠全,開發(fā)的業(yè)務(wù)功能就可以在完全不用更新 APK 的情況下崭参,做到熱更新呵曹。且用戶下一次打開應(yīng)用是最新的,這和 Native 的升級(jí)體驗(yàn)相比簡(jiǎn)直是一天一地。

跨平臺(tái)奄喂。之前安卓和 iOS 代碼需要開發(fā)兩次铐殃,現(xiàn)在一個(gè)功能決定用 H5 后,由一個(gè)工程師來開發(fā)一套代碼即可跨新。

這套動(dòng)態(tài)方案很大的缺點(diǎn)就是用戶體驗(yàn)差富腊,當(dāng)用 H5 做一些復(fù)雜的功能或動(dòng)畫時(shí),可能會(huì)卡頓的和 PPT 一樣域帐。因?yàn)?H5 的體驗(yàn)問題赘被,蜂鳥的原則是經(jīng)常更新的且功能不復(fù)雜的頁面會(huì)選擇用 H5。

第二階段:React Native

這個(gè)動(dòng)態(tài)方案完全脫離了以 H5 為基礎(chǔ)的 Hypid 方案肖揣,通過自定義 DSL 將 UI 渲染成原生控件民假,這樣一來, RN 的頁面就保證了原生的體驗(yàn)和 Web 的效率龙优。

除了上一點(diǎn)羊异,還有組件化開發(fā)、復(fù)用率高彤断、Android 和 iOS 95% 的代碼共用和測(cè)試效率高等優(yōu)點(diǎn)。

鑒于這些優(yōu)點(diǎn)宰衙,蜂鳥在 React Native 上做了很多事情平道,如 Crash 優(yōu)化、基礎(chǔ)控件沉淀菩浙、Bundle+ 圖片熱更新巢掺、首屏加載優(yōu)化和 Redux 單項(xiàng)數(shù)據(jù)流等句伶。

正當(dāng)享受 React Native 帶來的開發(fā)體驗(yàn)和應(yīng)用體驗(yàn)提升時(shí)劲蜻,蜂鳥遇到 RN 的一些痛點(diǎn),如 ScrollView 性能考余、Bundle 包過大先嬉、很多優(yōu)化都需要修改源碼和 peaking change 等。

第三階段:WEEX

面對(duì)如上這些痛點(diǎn)斩祭,不知如何應(yīng)對(duì)時(shí)酬蹋,WEEX 來了阀溶。官方宣傳的輕量、可擴(kuò)展和高性能等特點(diǎn)衅胀,讓蜂鳥團(tuán)隊(duì)眼前一亮。

經(jīng)深入研究后酥筝,蜂鳥發(fā)現(xiàn) WEEX 和 React Native 如出一轍滚躯,那么為什么要選擇類似的方案呢?

我們隊(duì) WEEX 和 React Native 兩者基于 JS 引擎、語法掸掏、數(shù)據(jù)流茁影、性能、開發(fā)體驗(yàn)及熱更新等維度進(jìn)行了對(duì)比丧凤。

如下圖募闲,是 WEEX 和 React Native JS 引擎對(duì)比:

React Native 在安卓和 iOS 使用的都是 JsCore,WEEX 在安卓端使用的是 UC 精簡(jiǎn)版 V8愿待。如上圖中的圖表可以看出浩螺,V8 相比 JsCore 要?jiǎng)僖换I。

WEEX 和 React Native 語法對(duì)比仍侥。語法方面年扩,React Native 使用的是 React,WEEX 使用的是 Vue访圃。雖然兩套方案都實(shí)現(xiàn)了如響應(yīng)式厨幻,組件化、狀態(tài)管理等功能腿时。

如下圖况脆,是兩者簡(jiǎn)單 Demo 的實(shí)踐:

實(shí)踐發(fā)現(xiàn),WEEX 相比 React Native 要優(yōu)雅一些批糟,是因?yàn)?Vue 有很多自定義標(biāo)簽格了,當(dāng)在做一些 UI 和邏輯交雜在一起時(shí),會(huì)讓代碼簡(jiǎn)潔很多徽鼎。

WEEX 和 React Native 的數(shù)據(jù)流對(duì)比盛末,React Native 使用 Redux,而 WEEX 使用 Vuex否淤,不是 WEEX 不能使用 Redux悄但,而是 Vuex 更適合 WEEX。

如下圖石抡,是兩者的數(shù)據(jù)流檐嚣,大同小異:

但 Vuex 在實(shí)現(xiàn)一些計(jì)算屬性時(shí),能在更細(xì)的顆粒度去更新 UI啰扛,而 Redux 只能實(shí)現(xiàn)到組件的級(jí)別嚎京,這樣的點(diǎn)很多的話會(huì)帶來性能上的差異。

如下圖隐解,是 WEEX 和 React Native 的性能對(duì)比鞍帝,左側(cè)是 WEEX 官方給出的與 React Native 在性能方面的對(duì)比圖:

在渲染時(shí)間和內(nèi)存占用方面 WEEX 要優(yōu)于 React Native,在 CPU 占用方面兩者相差不大煞茫,F(xiàn)PS 上 WEEX 要稍遜于 React Native帕涌。

在 ListView Android 方面岩臣,React Native 目前采用 ScrollView,WEEX 使用 Recyclerview 實(shí)現(xiàn)宵膨,性能稍好架谎。

同時(shí) WEEX 在增強(qiáng)開發(fā)、指定線程辟躏、首屏渲染和性能監(jiān)控等方面也做了優(yōu)化谷扣。

如下圖,是 WEEX 和 React Native 的開發(fā)體驗(yàn)對(duì)比:

和 React Native 相比捎琐,WEEX 在打包会涎、監(jiān)控性能、跨平臺(tái)等方面都有一定優(yōu)勢(shì)瑞凑∧┩海總體來說,React Native 更像是一個(gè)技術(shù)框架籽御,WEEX 更像是一個(gè)業(yè)務(wù)框架练慕。

如下圖,是 WEEX 和 React Native 的熱更新對(duì)比:

React Native 與 WEEX 官方都表示支持熱更新技掏,但他們的實(shí)現(xiàn)方式不同铃将。在 React Native 上可通過把圖片打包下發(fā)到本地來實(shí)現(xiàn)更新。

WEEX 有兩個(gè)方法哑梳,一是選擇本地資源加載劲阎,二是像網(wǎng)頁一樣直接加載頁面。

如下圖鸠真,是 React Native 與 WEEX 的對(duì)比總結(jié):

React Native 更像一個(gè)先驅(qū)者悯仙,擁有超強(qiáng)的社區(qū)人氣,但也因開源社區(qū)維護(hù)代碼的原因處于一個(gè)野蠻生長(zhǎng)的狀態(tài)吠卷。而 WEEX 是站在 React Native 的肩膀上锡垄,做了各種微創(chuàng)新,實(shí)現(xiàn)更多貼心的小細(xì)節(jié)撤嫩。

基于 WEEX 性能偎捎、穩(wěn)定性等方面都比 React Native 高,蜂鳥決定把動(dòng)態(tài)化方案往 WEEX 上遷移序攘,雖然它現(xiàn)在還有不足,有些輪子還是要自己去做寻拂。

蜂鳥團(tuán)隊(duì) WEEX 實(shí)踐

憑借之前 React Native 相關(guān)的實(shí)踐經(jīng)驗(yàn)程奠,基于 WEEX 做了一套更完整的動(dòng)態(tài)方案。涉及以下幾個(gè)方面祭钉,如下圖:

統(tǒng)一的pidge

在 Android & iOS 端瞄沙,約定相同的方法名、參數(shù),在 JS 層抹平平臺(tái)差異以及統(tǒng)一分類管理暴露給業(yè)務(wù)的 API距境。

把這樣的統(tǒng)一 pidge 方案提供給業(yè)務(wù)部門申尼,他們只需關(guān)心暴露的 API,而不需要關(guān)心下一層平臺(tái)的兼容垫桂,大大提升開發(fā)效率师幕。

加載更新策略

加載更新方面,我們約定了一套自有協(xié)議诬滩,有 Page霹粥、URL 和 Tag,通過封裝的 Router疼鸟,就可以做到頁面級(jí)的跳轉(zhuǎn)后控。

這樣一來,我們很輕松地做到了頁面的跳轉(zhuǎn)空镜、解耦和頁面的降級(jí)浩淘。當(dāng)頁面出現(xiàn)問題,只需要把 URL 改成降級(jí)之后的 H5 頁面下發(fā)即可吴攒,用戶觸及到的就是修復(fù)之后的 H5 頁面了馋袜。

如下圖,是預(yù)加載策略:

當(dāng) H5 頁面下發(fā)到客戶端之后舶斧,會(huì)對(duì)本地資源進(jìn)行檢查欣鳖,如果有 JS 文件,就忽略茴厉,沒有的話就把頁面下載泽台。當(dāng)用戶打開頁面,再去看本地矾缓,存在資源的話直接加載怀酷,不存在的話就即時(shí)下載再運(yùn)行,與傳統(tǒng)的 Web 流程相似嗜闻。

性能監(jiān)控

性能監(jiān)控用來判斷線上服務(wù)是否正常蜕依,是整套方案最重要的部分。

WEEX 可以很方便地將所有的參數(shù)全部拿到且通過反射拿到所有的性能數(shù)據(jù)傳到云端琉雳。

基于這些數(shù)據(jù)样眠,我們就可以知道線上有了哪些頁面,它的渲染是否有問題翠肘¢苁基于這些問題,就可做相應(yīng)的優(yōu)化束倍。

如下圖被丧,是線上的數(shù)據(jù)情況:

wKioL1mWR1_yo0slAACw7OO3gPA560.jpg

監(jiān)控三個(gè)指標(biāo)盟戏,分別是 JS 引擎的初始化時(shí)間、頁面打開時(shí)間和網(wǎng)絡(luò)時(shí)間甥桂。因大部分 WEEX 頁面都是業(yè)務(wù)柿究,所以說業(yè)務(wù)埋點(diǎn)必不可少。餓了么也實(shí)現(xiàn)了一套框架黄选,將業(yè)務(wù)埋點(diǎn)傳給服務(wù)端蝇摸,然后方便產(chǎn)品去制定一些產(chǎn)品方面的策略。

JS 的錯(cuò)誤統(tǒng)計(jì)

可以捕捉 JS 端拋出的錯(cuò)誤糕簿,如果所處團(tuán)隊(duì)是前端主導(dǎo)探入,可傳給前端。如果是 Native 主導(dǎo)懂诗,可通過搜集平臺(tái)將這些崩潰上傳蜂嗽,在后臺(tái)看到這些錯(cuò)誤之后,找到相應(yīng)的代碼去修復(fù)殃恒。

Native 的錯(cuò)誤

有了 JS 錯(cuò)誤植旧,Native 錯(cuò)誤也不能忽略。

如下圖离唐,是 WEEX 動(dòng)態(tài)方案上線一周之后線上拋的錯(cuò)誤:

從圖中可以看到都是個(gè)位數(shù)病附,這一點(diǎn)其實(shí)當(dāng)時(shí)也很驚訝,WEEX 確實(shí)做得很穩(wěn)定亥鬓,這一點(diǎn)超出預(yù)料完沪。

共用組件和 API

之前蜂鳥在 React Native 上面的一些實(shí)踐,積累了一些很常用的組件和 API嵌戈。WEEX 和 React Native 都是使用 JS 實(shí)現(xiàn)覆积,所以我們很方便的將 RN 的控件轉(zhuǎn)化為 WEEX 控件。

如下圖熟呛,是實(shí)現(xiàn)的組件和 API宽档,幾乎可以滿足中小團(tuán)隊(duì)的日常使用:

調(diào)試工具

這方面 WEEX 做的很貼心,雖然沒有整合到整個(gè)初始化的項(xiàng)目中庵朝,但開源了幾個(gè)庫(kù)吗冤,可把代碼拷貝到業(yè)務(wù)中進(jìn)行使用。

WEEX 還可支持 Debug 模式顯示調(diào)試工具九府、支持 hot reload椎瘟、方便的查看性能指標(biāo)和 Shell 腳本一鍵打包等功能。

綜上所述昔逗,基于這些維度實(shí)現(xiàn)的框架降传,可以方便的讓業(yè)務(wù)來使用。

如下勾怒,是餓了么和蜂鳥用 WEEX 實(shí)現(xiàn)的兩個(gè)頁面:

餓了么的第二個(gè)發(fā)現(xiàn)頁面婆排,就是基于 WEEX。蜂鳥 APP 可能大家接觸不到笔链,上圖是當(dāng)前通知的活動(dòng)界面段只,還有大量的新功能正在接入。

如果你正在考慮 WEEX 與 React Native 方案鉴扫,或是正在接入 React Native赞枕。看到這篇文章坪创,你可以去調(diào)研以下 WEEX 方案炕婶,可能你會(huì)有另一種選擇。

以上內(nèi)容根據(jù)許錦洋老師在 WOTA2017 “移動(dòng)端架構(gòu)演進(jìn)”專場(chǎng)的演講內(nèi)容整理莱预。

負(fù)責(zé)餓了么蜂鳥 APP 的架構(gòu)柠掂、研發(fā)等工作。擁有餓了么商家依沮、風(fēng)行者涯贞、蜂鳥眾包等多款 APP 開發(fā)工作經(jīng)歷,并從 0 開始架構(gòu)和開發(fā)了整個(gè)蜂鳥團(tuán)隊(duì) APP危喉。目前關(guān)注的技術(shù)方向?yàn)橐苿?dòng)跨平臺(tái)技術(shù)方案宋渔、移動(dòng)端架構(gòu)、移動(dòng)端性能優(yōu)化等辜限。

【轉(zhuǎn)載 51CTO原創(chuàng)稿件】

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末皇拣,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子薄嫡,更是在濱河造成了極大的恐慌氧急,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件岂座,死亡現(xiàn)場(chǎng)離奇詭異态蒂,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)费什,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門钾恢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鸳址,你說我怎么就攤上這事瘩蚪。” “怎么了稿黍?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵疹瘦,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我巡球,道長(zhǎng)言沐,這世上最難降的妖魔是什么邓嘹? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮险胰,結(jié)果婚禮上汹押,老公的妹妹穿的比我還像新娘。我一直安慰自己起便,他們只是感情好棚贾,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著榆综,像睡著了一般妙痹。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鼻疮,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天怯伊,我揣著相機(jī)與錄音,去河邊找鬼陋守。 笑死震贵,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的水评。 我是一名探鬼主播猩系,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼中燥!你這毒婦竟也來了寇甸?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤疗涉,失蹤者是張志新(化名)和其女友劉穎拿霉,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體咱扣,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绽淘,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了闹伪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沪铭。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖偏瓤,靈堂內(nèi)的尸體忽然破棺而出杀怠,到底是詐尸還是另有隱情,我是刑警寧澤厅克,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布赔退,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏硕旗。R本人自食惡果不足惜窗骑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望卵渴。 院中可真熱鬧慧域,春花似錦鲤竹、人聲如沸浪读。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽碘橘。三九已至,卻和暖如春吱肌,著一層夾襖步出監(jiān)牢的瞬間痘拆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工氮墨, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留纺蛆,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓规揪,卻偏偏與公主長(zhǎng)得像桥氏,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子猛铅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344