84 个JavaScript 代码片段(持续更新)

JavaScript 是目前最流行的编程语言之一,正如大多数人所说:“如果你想学一门编程语言,请学JavaScript。”

FreeCodeCamp的创始人 Quincy Larson 在最近的一次采访中被问到哪种语言开发人员应该首先学习。他回答:“ JavaScript。”

“软件正在吞噬世界,JavaScript正在吞噬软件。JavaScript每年都在变得越来越占主导地位,而且没人知道最终会取代它的是什么。"

如果您没有充分的理由学习一种新语言(例如您的工作要求您维护非JavaScript代码库),那么我的建议是着重于提高JavaScript的水平。”

听我说这么多,你是不是很激动呢。这里有127个常用的JS代码片段,方便你学习和使用。

1、all

如果数组所有元素满足函数条件,则返回true。调用时,如果省略第二个参数,则默认传递布尔值。

constall=(arr,fn=Boolean)=>arr.every(fn);

all([4,2,3],x=>x>1);// true

all([1,2,3]);// true

2、allEqual

判断数组中的元素是否都相等

constallEqual=arr=>arr.every(val=>val===arr[0]);

allEqual([1,2,3,4,5,6]);// false

allEqual([1,1,1,1]);// true

3、approximatelyEqual

此代码示例检查两个数字是否近似相等,差异值可以通过传参的形式进行设置

constapproximatelyEqual=(v1,v2,epsilon=0.001)=>Math.abs(v1-v2)<epsilon;

approximatelyEqual(Math.PI/2.0,1.5708);// true

4、arrayToCSV

此段代码将没有逗号或双引号的元素转换成带有逗号分隔符的字符串即CSV格式识别的形式。

constarrayToCSV=(arr,delimiter=',')=>

arr.map(v=>v.map(x=>`"${x}"`).join(delimiter)).join('\n');

arrayToCSV([['a','b'],['c','d']]);// '"a","b"\n"c","d"'

arrayToCSV([['a','b'],['c','d']],';');// '"a";"b"\n"c";"d"'

5、arrayToHtmlList

此段代码将数组元素转换成<li>标记,并将此元素添加至给定的ID元素标记内。

constarrayToHtmlList=(arr,listID)=>(el=>(

    (el=document.querySelector('#'+listID)),

    (el.innerHTML+=arr.map(item=>`<li>${item}</li>`).join(''))

))();

arrayToHtmlList(['item 1','item 2'],'myListID');

6、attempt

此段代码执行一个函数,将剩余的参数传回函数当参数,返回相应的结果,并能捕获异常。

constattempt=(fn,...args)=>{

    try{

        returnfn(...args);

    }catch(e){

        returneinstanceofError?e:newError(e);

    }

};

varelements=attempt(function(selector){

returndocument.querySelectorAll(selector);

},'>_>');

if(elementsinstanceofError)elements=[];// elements = []

7、average

此段代码返回两个或多个数的平均数。

constaverage=(...nums)=>nums.reduce((acc,val)=>acc+val,0)/nums.length;

average(...[1,2,3]);// 2

average(1,2,3);// 2

8、averageBy

一个 map()函数和 reduce()函数结合的例子,此函数先通过 map() 函数将对象转换成数组,然后在调用reduce()函数进行累加,然后根据数组长度返回平均值。

constaverageBy=(arr,fn)=>

arr.map(typeoffn==='function'?fn:val=>val[fn]).reduce((acc,val)=>acc+val,0)/

arr.length;

averageBy([{n:4},{n:2},{n:8},{n:6}],o=>o.n);// 5

averageBy([{n:4},{n:2},{n:8},{n:6}],'n');// 5

9、bifurcate

此函数包含两个参数,类型都为数组,依据第二个参数的真假条件,将一个参数的数组进行分组,条件为真的放入第一个数组,其它的放入第二个数组。这里运用了Array.prototype.reduce() 和 Array.prototype.push() 相结合的形式。

constbifurcate=(arr,filter)=>

arr.reduce((acc,val,i)=>(acc[filter[i]?0:1].push(val),acc),[[],[]]);

bifurcate(['beep','boop','foo','bar'],[true,true,false,true]);

// [ ['beep', 'boop', 'bar'], ['foo'] ]

10、bifurcateBy

此段代码将数组按照指定的函数逻辑进行分组,满足函数条件的逻辑为真,放入第一个数组中,其它不满足的放入第二个数组 。这里运用了Array.prototype.reduce() 和 Array.prototype.push() 相结合的形式,基于函数过滤逻辑,通过 Array.prototype.push() 函数将其添加到数组中。

constbifurcateBy=(arr,fn)=>

arr.reduce((acc,val,i)=>(acc[fn(val,i)?0:1].push(val),acc),[[],[]]);

bifurcateBy(['beep','boop','foo','bar'],x=>x[0]==='b');

// [ ['beep', 'boop', 'bar'], ['foo'] ]

11、bottomVisible

用于检测页面是否滚动到页面底部。

constbottomVisible=()=>

document.documentElement.clientHeight+window.scrollY>=

(document.documentElement.scrollHeight||document.documentElement.clientHeight);

bottomVisible();// true

12、byteSize

此代码返回字符串的字节长度。这里用到了Blob对象,Blob(Binary Large Object)对象代表了一段二进制数据,提供了一系列操作接口。其他操作二进制数据的API(比如File对象),都是建立在Blob对象基础上的,继承了它的属性和方法。生成Blob对象有两种方法:一种是使用Blob构造函数,另一种是对现有的Blob对象使用slice方法切出一部分。

constbyteSize=str=>newBlob([str]).size;

byteSize('😀');// 4

byteSize('Hello World');// 11

13、capitalize

将字符串的首字母转成大写,这里主要运用到了ES6的展开语法在数组中的运用。

constcapitalize=([first,...rest])=>

first.toUpperCase()+rest.join('');

capitalize('fooBar');// 'FooBar'

capitalize('fooBar',true);// 'FooBar'

14、capitalizeEveryWord

将一个句子中每个单词首字母转换成大写字母,这里中要运用了正则表达式进行替换。

constcapitalizeEveryWord=str=>str.replace(/\b[a-z]/g,char=>char.toUpperCase());

capitalizeEveryWord('hello world!');// 'Hello World!'

15、castArray

此段代码将非数值的值转换成数组对象。

constcastArray=val=>(Array.isArray(val)?val:[val]);

castArray('foo');// ['foo']

castArray([1]);// [1]

16、compact

将数组中移除值为 false 的内容。

constcompact=arr=>arr.filter(Boolean);

compact([0,1,false,2,'',3,'a','e'*23,NaN,'s',34]);

// [ 1, 2, 3, 'a', 's', 34 ]

17、countOccurrences

统计数组中某个值出现的次数

constcountOccurrences=(arr,val)=>arr.reduce((a,v)=>(v===val?a+1:a),0);

countOccurrences([1,1,2,1,2,3],1);// 3

18、Create Directory

此代码段使用 existSync() 检查目录是否存在,然后使用 mkdirSync() 创建目录(如果不存在)。

constfs=require('fs');

constcreateDirIfNotExists=dir=>(!fs.existsSync(dir)?fs.mkdirSync(dir):undefined);

createDirIfNotExists('test');

// creates the directory 'test', if it doesn't exist

19、currentURL

返回当前访问的 URL 地址。

constcurrentURL=()=>window.location.href;

currentURL();// 'https://medium.com/@fatosmorina'

20、dayOfYear

返回当前是今年的第几天

constdayOfYear=date=>

Math.floor((date-newDate(date.getFullYear(),0,0))/1000/60/60/24);

dayOfYear(newDate());// 272

21、decapitalize

将字符串的首字母转换成小写字母

constdecapitalize=([first,...rest])=>

first.toLowerCase()+rest.join('')

decapitalize('FooBar');// 'fooBar'


22、deepFlatten

通过递归的形式,将多维数组展平成一维数组。

constdeepFlatten=arr=>[].concat(...arr.map(v=>(Array.isArray(v)?deepFlatten(v):v)));

deepFlatten([1,[2],[[3],4],5]);// [1,2,3,4,5]

23、default

去重对象的属性,如果对象中含有重复的属性,以前面的为准。

constdefaults=(obj,...defs)=>Object.assign({},obj,...defs.reverse(),obj);

defaults({a:1},{b:2},{b:6},{a:3});// { a: 1, b: 2 }

24、defer

延迟函数的调用,即异步调用函数。

constdefer=(fn,...args)=>setTimeout(fn,1,...args);

defer(console.log,'a'),console.log('b');// logs 'b' then 'a'

25、degreesToRads

此段代码将标准的度数,转换成弧度。

constdegreesToRads=deg=>(deg*Math.PI)/180.0;

degreesToRads(90.0);// ~1.5708

26、difference

此段代码查找两个给定数组的差异,查找出前者数组在后者数组中不存在元素。

constdifference=(a,b)=>{

consts=newSet(b);

returna.filter(x=>!s.has(x));

};

difference([1,2,3],[1,2,4]);// [3]

27、differenceBy

通过给定的函数来处理需要对比差异的数组,查找出前者数组在后者数组中不存在元素。

constdifferenceBy=(a,b,fn)=>{

consts=newSet(b.map(fn));

returna.filter(x=>!s.has(fn(x)));

};

differenceBy([2.1,1.2],[2.3,3.4],Math.floor);// [1.2]

differenceBy([{x:2},{x:1}],[{x:1}],v=>v.x);// [ { x: 2 } ]

28、differenceWith

此段代码按照给定函数逻辑筛选需要对比差异的数组,查找出前者数组在后者数组中不存在元素。

constdifferenceWith=(arr,val,comp)=>arr.filter(a=>val.findIndex(b=>comp(a,b))===-1);

differenceWith([1,1.2,1.5,3,0],[1.9,3,0],(a,b)=>Math.round(a)===Math.round(b));

// [1, 1.2]

29、digitize

将输入的数字拆分成单个数字组成的数组。

constdigitize=n=>[...`${n}`].map(i=>parseInt(i));

digitize(431);// [4, 3, 1]

30、distance

计算两点之间的距离

constdistance=(x0,y0,x1,y1)=>Math.hypot(x1-x0,y1-y0);

distance(1,1,2,3);// 2.23606797749979

31、drop

此段代码将给定的数组从左边开始删除 n 个元素

constdrop=(arr,n=1)=>arr.slice(n);

drop([1,2,3]);// [2,3]

drop([1,2,3],2);// [3]

drop([1,2,3],42);// []

32、dropRight

此段代码将给定的数组从右边开始删除 n 个元素

constdropRight=(arr,n=1)=>arr.slice(0,-n);

dropRight([1,2,3]);// [1,2]

dropRight([1,2,3],2);// [1]

dropRight([1,2,3],42);// []

33、dropRightWhile

此段代码将给定的数组按照给定的函数条件从右开始删除,直到当前元素满足函数条件为True时,停止删除,并返回数组剩余元素。

constdropRightWhile=(arr,func)=>{

while(arr.length>0&&!func(arr[arr.length-1]))arr=arr.slice(0,-1);

returnarr;

};

dropRightWhile([1,2,3,4],n=>n<3);// [1, 2]

34、dropWhile

按照给定的函数条件筛选数组,不满足函数条件的将从数组中移除。

constdropWhile=(arr,func)=>{

while(arr.length>0&&!func(arr[0]))arr=arr.slice(1);

returnarr;

};

dropWhile([1,2,3,4],n=>n>=3);// [3,4]

35、elementContains

接收两个DOM元素对象参数,判断后者是否是前者的子元素。

constelementContains=(parent,child)=>parent!==child&&parent.contains(child);

elementContains(document.querySelector('head'),document.querySelector('title'));// true

elementContains(document.querySelector('body'),document.querySelector('body'));// false

36、filterNonUnique

移除数组中重复的元素

constfilterNonUnique=arr=>[…newSet(arr)];

filterNonUnique([1,2,2,3,4,4,5]);// [1, 2, 3, 4, 5]

37、findKey

按照给定的函数条件,查找第一个满足条件对象的键值。

constfindKey=(obj,fn)=>Object.keys(obj).find(key=>fn(obj[key],key,obj));

findKey(

{

barney:{age:36,active:true},

fred:{age:40,active:false},

pebbles:{age:1,active:true}

},

o=>o['active']

);// 'barney'

38、findLast

按照给定的函数条件筛选数组,将最后一个满足条件的元素进行删除。

constfindLast=(arr,fn)=>arr.filter(fn).pop();

findLast([1,2,3,4],n=>n%2===1);// 3

39、flatten

按照指定数组的深度,将嵌套数组进行展平。

constflatten=(arr,depth=1)=>

arr.reduce((a,v)=>a.concat(depth>1&&Array.isArray(v)?flatten(v,depth-1):v),[]);

flatten([1,[2],3,4]);// [1, 2, 3, 4]

flatten([1,[2,[3,[4,5],6],7],8],2);// [1, 2, 3, [4, 5], 6, 7, 8]

40、forEachRight

按照给定的函数条件,从数组的右边往左依次进行执行。

constforEachRight=(arr,callback)=>

arr

.slice(0)

.reverse()

.forEach(callback);

forEachRight([1,2,3,4],val=>console.log(val));// '4', '3', '2', '1'

41、forOwn

此段代码按照给定的函数条件,进行迭代对象。

constforOwn=(obj,fn)=>Object.keys(obj).forEach(key=>fn(obj[key],key,obj));

forOwn({foo:'bar',a:1},v=>console.log(v));// 'bar', 1

42、functionName

此段代码输出函数的名称。

constfunctionName=fn=>(console.debug(fn.name),fn);

functionName(Math.max);// max (logged in debug channel of console)

43、getColonTimeFromDate

此段代码从Date对象里获取当前时间。

constgetColonTimeFromDate=date=>date.toTimeString().slice(0,8);

getColonTimeFromDate(newDate());// "08:38:00"

44、getDaysDiffBetweenDates

此段代码返回两个日期之间相差多少天

constgetDaysDiffBetweenDates=(dateInitial,dateFinal)=>

(dateFinal-dateInitial)/(1000*3600*24);

getDaysDiffBetweenDates(newDate('2019-01-13'),newDate('2019-01-15'));// 2

45、getStyle

此代码返回DOM元素节点对应的属性值。

constgetStyle=(el,ruleName)=>getComputedStyle(el)[ruleName];

getStyle(document.querySelector('p'),'font-size');// '16px'

46、getType

此段代码的主要功能就是返回数据的类型。

constgetType=v=>

v===undefined?'undefined':v===null?'null':v.constructor.name.toLowerCase();

getType(newSet([1,2,3]));// 'set'

47、hasClass

此段代码返回DOM元素是否包含指定的Class样式。

consthasClass=(el,className)=>el.classList.contains(className);

hasClass(document.querySelector('p.special'),'special');// true

48、head

此段代码输出数组的第一个元素。

consthead=arr=>arr[0];

head([1,2,3]);// 1

49、hide

此段代码隐藏指定的DOM元素。

consthide=(...el)=>[...el].forEach(e=>(e.style.display='none'));

hide(document.querySelectorAll('img'));// Hides all <img> elements on the page

50、httpsRedirect

此段代码的功能就是将http网址重定向https网址。

consthttpsRedirect=()=>{

if(location.protocol!=='https:')location.replace('https://'+location.href.split('//')[1]);

};

httpsRedirect();// If you are on http://mydomain.com, you are redirected to https://mydomain.com

51、indexOfAll

此代码可以返回数组中某个值对应的所有索引值,如果不包含该值,则返回一个空数组。

constindexOfAll=(arr,val)=>arr.reduce((acc,el,i)=>(el===val?[...acc,i]:acc),[]);

indexOfAll([1,2,3,1,2,3],1);// [0,3]

indexOfAll([1,2,3],4);// []

52、initial

此段代码返回数组中除最后一个元素的所有元素

constinitial=arr=>arr.slice(0,-1);

initial([1,2,3]);// [1,2]const initial = arr => arr.slice(0, -1);

initial([1,2,3]);// [1,2]

53、insertAfter

此段代码的功能主要是在给定的DOM节点后插入新的节点内容

constinsertAfter=(el,htmlString)=>el.insertAdjacentHTML('afterend',htmlString);

insertAfter(document.getElementById('myId'),'<p>after</p>');// <div id="myId">...</div> <p>after</p>

54、insertBefore

此段代码的功能主要是在给定的DOM节点前插入新的节点内容

constinsertBefore=(el,htmlString)=>el.insertAdjacentHTML('beforebegin',htmlString);

insertBefore(document.getElementById('myId'),'<p>before</p>');// <p>before</p> <div id="myId">...</div>

55、intersection

此段代码返回两个数组元素之间的交集。

constintersection=(a,b)=>{

consts=newSet(b);

returna.filter(x=>s.has(x));

};

intersection([1,2,3],[4,3,2]);// [2, 3]

56、intersectionBy

按照给定的函数处理需要对比的数组元素,然后根据处理后的数组,找出交集,最后从第一个数组中将对应的元素输出。

constintersectionBy=(a,b,fn)=>{

consts=newSet(b.map(fn));

returna.filter(x=>s.has(fn(x)));

};

intersectionBy([2.1,1.2],[2.3,3.4],Math.floor);// [2.1]

57、intersectionBy

按照给定的函数对比两个数组的差异,然后找出交集,最后从第一个数组中将对应的元素输出。

constintersectionWith=(a,b,comp)=>a.filter(x=>b.findIndex(y=>comp(x,y))!==-1);

intersectionWith([1,1.2,1.5,3,0],[1.9,3,0,3.9],(a,b)=>Math.round(a)===Math.round(b));// [1.5, 3, 0]

58、is

此段代码用于判断数据是否为指定的数据类型,如果是则返回true。

constis=(type,val)=>![,null].includes(val)&&val.constructor===type;

is(Array,[1]);// true

is(ArrayBuffer,newArrayBuffer());// true

is(Map,newMap());// true

is(RegExp,/./g);// true

is(Set,newSet());// true

is(WeakMap,newWeakMap());// true

is(WeakSet,newWeakSet());// true

is(String,'');// true

is(String,newString(''));// true

is(Number,1);// true

is(Number,newNumber(1));// true

is(Boolean,true);// true

is(Boolean,newBoolean(true));// true

59、isAfterDate

接收两个日期类型的参数,判断前者的日期是否晚于后者的日期。

constisAfterDate=(dateA,dateB)=>dateA>dateB;

isAfterDate(newDate(2010,10,21),newDate(2010,10,20));// true

60、isAnagram

用于检测两个单词是否相似。

constisAnagram=(str1,str2)=>{

constnormalize=str=>

str

.toLowerCase()

.replace(/[^a-z0-9]/gi,'')

.split('')

.sort()

.join('');

returnnormalize(str1)===normalize(str2);

};

isAnagram('iceman','cinema');// true

61、isArrayLike

此段代码用于检测对象是否为类数组对象,是否可迭代。

constisArrayLike=obj=>obj!=null&&typeofobj[Symbol.iterator]==='function';

isArrayLike(document.querySelectorAll('.className'));// true

isArrayLike('abc');// true

isArrayLike(null);// false

62、isBeforeDate

接收两个日期类型的参数,判断前者的日期是否早于后者的日期。

constisBeforeDate=(dateA,dateB)=>dateA<dateB;

isBeforeDate(newDate(2010,10,20),newDate(2010,10,21));// true

63、isBoolean

此段代码用于检查参数是否为布尔类型。

constisBoolean=val=>typeofval==='boolean';

isBoolean(null);// false

isBoolean(false);// true

64、getColonTimeFromDate

用于判断程序运行环境是否在浏览器,这有助于避免在node环境运行前端模块时出错。

constisBrowser=()=>![typeofwindow,typeofdocument].includes('undefined');

isBrowser();// true (browser)

isBrowser();// false (Node)

65、isBrowserTabFocused

用于判断当前页面是否处于活动状态(显示状态)。

constisBrowserTabFocused=()=>!document.hidden;

isBrowserTabFocused();// true

66、isLowerCase

用于判断当前字符串是否都为小写。

constisLowerCase=str=>str===str.toLowerCase();

isLowerCase('abc');// true

isLowerCase('a3@$');// true

isLowerCase('Ab4');// false

67、isNil

用于判断当前变量的值是否为 null 或 undefined 类型。

constisNil=val=>val===undefined||val===null;

isNil(null);// true

isNil(undefined);// true

68、isNull

用于判断当前变量的值是否为 null 类型。

constisNull=val=>val===null;

isNull(null);// true

69、isNumber

用于检查当前的值是否为数字类型。

functionisNumber(n){

return!isNaN(parseFloat(n))&&isFinite(n);

}

isNumber('1');// false

isNumber(1);// true

70、isObject

用于判断参数的值是否是对象,这里运用了Object 构造函数创建一个对象包装器,如果是对象类型,将会原值返回。

constisObject=obj=>obj===Object(obj);

isObject([1,2,3,4]);// true

isObject([]);// true

isObject(['Hello!']);// true

isObject({a:1});// true

isObject({});// true

isObject(true);// false

71、isObjectLike

用于检查参数的值是否为null以及类型是否为对象。

constisObjectLike=val=>val!==null&&typeofval==='object';

isObjectLike({});// true

isObjectLike([1,2,3]);// true

isObjectLike(x=>x);// false

isObjectLike(null);// false

72、isPlainObject

此代码段检查参数的值是否是由Object构造函数创建的对象。

constisPlainObject=val=>!!val&&typeofval==='object'&&val.constructor===Object;

isPlainObject({a:1});// true

isPlainObject(newMap());// false

73、isPromiseLike

用于检查当前的对象是否类似Promise函数。

constisPromiseLike=obj=>

obj!==null&&

(typeofobj==='object'||typeofobj==='function')&&

typeofobj.then==='function';

isPromiseLike({

then:function(){

return'';

}

});// true

isPromiseLike(null);// false

isPromiseLike({});// false

74、isSameDate

用于判断给定的两个日期是否是同一天。

constisSameDate=(dateA,dateB)=>dateA.toISOString()===dateB.toISOString();

isSameDate(newDate(2010,10,20),newDate(2010,10,20));// true

75、isString

用于检查当前的值是否为字符串类型。

constisString=val=>typeofval==='string';

isString('10');// true

76、isSymbol

用于判断参数的值是否是 Symbol 类型。

constisSymbol=val=>typeofval==='symbol';

isSymbol(Symbol('x'));// true

77、isUndefined

用于判断参数的类型是否是 Undefined 类型。

constisUndefined=val=>val===undefined;

isUndefined(undefined);// true

78、isUpperCase

用于判断当前字符串的字母是否都为大写。

constisUpperCase=str=>str===str.toUpperCase();

isUpperCase('ABC');// true

isLowerCase('A3@$');// true

isLowerCase('aB4');// false

79、isValidJSON

用于判断给定的字符串是否是 JSON 字符串。

constisValidJSON=str=>{

try{

JSON.parse(str);

returntrue;

}catch(e){

returnfalse;

}

};

isValidJSON('{"name":"Adam","age":20}');// true

isValidJSON('{"name":"Adam",age:"20"}');// false

isValidJSON(null);// true

80、last

此函数功能返回数组的最后一个元素。

constlast=arr=>arr[arr.length-1];

last([1,2,3]);// 3

81、matches

此函数功能用于比较两个对象,以确定第一个对象是否包含与第二个对象相同的属性与值。

onstmatches=(obj,source)=>

Object.keys(source).every(key=>obj.hasOwnProperty(key)&&obj[key]===source[key]);

matches({age:25,hair:'long',beard:true},{hair:'long',beard:true});// true

matches({hair:'long',beard:true},{age:25,hair:'long',beard:true});// false

82、maxDate

此代码段查找日期数组中最大的日期进行输出。

constmaxDate=(...dates)=>newDate(Math.max.apply(null,...dates));

constarray=[

newDate(2017,4,13),

newDate(2018,2,12),

newDate(2016,0,10),

newDate(2016,0,9)

];

maxDate(array);// 2018-03-11T22:00:00.000Z

83、maxN

此段代码输出数组中前 n 位最大的数。

constmaxN=(arr,n=1)=>[...arr].sort((a,b)=>b-a).slice(0,n);

maxN([1,2,3]);// [3]

maxN([1,2,3],2);// [3,2]

84、minDate

此代码段查找日期数组中最早的日期进行输出。

constminDate=(...dates)=>newDate(Math.min.apply(null,...dates));

constarray=[

newDate(2017,4,13),

newDate(2018,2,12),

newDate(2016,0,10),

newDate(2016,0,9)

];

minDate(array);// 2016-01-08T22:00:00.000Z

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