NodeJS后台
2019-05-29 本文已影响9人
魔王哪吒
NodeJS后台
后台:
1.PHP
2.Java
3.Python
优势
1.性能
2.跟前台JS配合方便
3.NodeJS便于前端学习
data:image/s3,"s3://crabby-images/77443/774431f9064378784c41bb9015b59ed59fee125f" alt=""
data:image/s3,"s3://crabby-images/e72bf/e72bf1edf999ad1e01ba476be8421dc9f8704fdc" alt=""
data:image/s3,"s3://crabby-images/350a9/350a94a00b43aaf64a35fb2b7386632e84d9c1c7" alt=""
1.切换盘符 e:
2.改变目录 cd 目录名
3.执行程序 node xxx.js
const http = require('http');
http.createServer(function(req, res){
// 前台响应
res.write("dashucoding");
res.end();
});
// 监听
// 端口
server.listen(123);
nodeJS——服务器
http——协议
request 请求
response 响应
data:image/s3,"s3://crabby-images/859b0/859b0728e86cfc751c4fe903ff11e75f8fbb9979" alt=""
文件操作:fs——File System
http——模块
异步 vs 同步
异步——多个操作可以同时进行,前一次的操作没完事,后一次也能开始
同步——一次一个
const fs=require('fs');
// readFile(文件名,回调函数)
readFile(文件名, function (err, data){})
writeFile(文件名, 内容, function (err){})
oBtn.onclick=function (){
alert('a');
};
alert('b');
data:image/s3,"s3://crabby-images/4d545/4d545860840515bd7401dce8a86119fe207a1532" alt=""
data:image/s3,"s3://crabby-images/999bf/999bfdd0ff19467e589cc509bad2a3c27215cbc5" alt=""
data:image/s3,"s3://crabby-images/c2ca8/c2ca8242d985e4a2fc81edbabd488a52bb6c98d9" alt=""
const http=require('http');
const fs=require('fs');
var server=http.createServer(function (req, res){
//req.url=>'/index.html'
//读取=>'./www/index.html'
// './www'+req.url
var file_name='./www'+req.url;
fs.readFile(file_name, function (err, data){
if(err){
res.write('404');
}else{
res.write(data);
}
res.end();
});
});
server.listen(8080);
const fs=require('fs');
//writeFile(文件名, 内容, 回调)
fs.writeFile("bbb.txt", "dda", function (err){
console.log(err);
});
const fs=require('fs');
//readFile(文件名, 回调函数)
fs.readFile('aaa.txt', function (err, data){
if(err){
console.log('读取失败');
}else{
console.log(data.toString());
}
});
//fs.writeFile
buffer类用于二进制数据的存储提供一个缓存区
settimeout函数用于指定时间到达执行一个指定函数,指定方法为从当前时刻之后多少毫秒
cleartimeout函数用于取消在settimeout函数内指定的函数的执行
var http = require('http');
http.createServer(function(req,res){
res.writeHead(200, {'Content-Type':'text/html'});
res.write('<head><meta charset="utf-8"/></head>');
res.end('你好\n');
}).listen(1234,"127.0.0.1");
var http=require('http');
http.createServer(function(req,res){
// 回调函数中的代码
})
data:image/s3,"s3://crabby-images/65535/65535dad24f256c4af0068bf496419f105d817a5" alt=""
//一行
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
word-break: break-all;
//两行
text-overflow: -o-ellipsis-lastline;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
line-clamp: 2;
-webkit-box-orient: vertical;
data:image/s3,"s3://crabby-images/9403a/9403ac96e0b97963af2713d028bd1426e8fc9323" alt=""
data:image/s3,"s3://crabby-images/cc9ea/cc9eaac4ae4340dc23ed868a8144c16d4a82dbfe" alt=""
小程序简单实现双击事件
data = {
tabBar: [],
// recommendList: [],
floorList: [],
banners: [],
currentIndex: 1,
canGetCoupon: false,
// 触摸开始时间
touchStartTime: 0,
// 触摸结束时间
touchEndTime: 0,
// 最后一次单击事件点击发生时间
lastTapTime: 0
}
getCoupon: function (e) {
let that = this
if (that.touchEndTime - that.touchStartTime < 350) {
// 当前点击的时间
let currentTime = e.timeStamp
let lastTapTime = that.lastTapTime
// 更新最后一次点击时间
that.lastTapTime = currentTime
// 如果两次点击时间在300毫秒内,则认为是双击事件
if (currentTime - lastTapTime < 300) {
// 成功触发双击事件时,取消单击事件的执行
// clearTimeout(that.lastTapTimeoutFunc)
getCoupon({}).then(res => {
this.canGetCoupon = false
})
wx.showToast({
title: '优惠券领取成功',
duration: 3000
})
}
}
doubleClick(e){
//e.timeStamp:当前点击时的毫秒数;
// this.touchStartTime: 储存上一次点击时的毫秒数,默认0
if (e.timeStamp - this.touchStartTime < 300){
双击,进入
}
this.touchStartTime = e.timeStamp;
单击
}
/*
if ((e.timeStamp - this.touchStartTime) < 100) {
getCoupon({}).then(res => {
this.canGetCoupon = false
})
wx.showToast({
title: '领取成功',
icon: 'none',
duration: 3000
})
}
this.touchStartTime = e.timeStamp
*/
// 触摸开始时间
touchStartTime: 0,
// 触摸结束时间
touchEndTime: 0,
// 最后一次单击事件点击发生时间
lastTapTime: 0,
// 单击事件点击后要触发的函数
lastTapTimeoutFunc: null,
/// 双击
doubleTap: function(e) {
var that = this
// 控制点击事件在350ms内触发,加这层判断是为了防止长按时会触发点击事件
if (that.touchEndTime - that.touchStartTime < 350) {
// 当前点击的时间
var currentTime = e.timeStamp
var lastTapTime = that.lastTapTime
// 更新最后一次点击时间
that.lastTapTime = currentTime
// 如果两次点击时间在300毫秒内,则认为是双击事件
if (currentTime - lastTapTime < 300) {
console.log("double tap")
// 成功触发双击事件时,取消单击事件的执行
clearTimeout(that.lastTapTimeoutFunc);
wx.showModal({
title: '提示',
content: '双击事件被触发',
showCancel: false
})
}
}
},
data:image/s3,"s3://crabby-images/b6679/b6679c1d262d8defa306b4b9996da92be0b94955" alt=""
data:image/s3,"s3://crabby-images/69da2/69da2a8b3e9542ba5412bdb798df2fc2f6495f26" alt=""
data:image/s3,"s3://crabby-images/dd710/dd7103c82afb1775ec7560d1700c417ad980a4b9" alt=""
data:image/s3,"s3://crabby-images/b1ce2/b1ce2c38949c266da6307958211f86d1cc365ba0" alt=""
data:image/s3,"s3://crabby-images/35054/35054ee05a338ce0791d748f6c997181eecb9247" alt=""
data:image/s3,"s3://crabby-images/cfbc6/cfbc6e19bc35c0ff4cb9de68a97eb8e6c46471a6" alt=""
data:image/s3,"s3://crabby-images/40a98/40a98953cdee18f81614f15533407d26eb540af7" alt=""
data:image/s3,"s3://crabby-images/30de0/30de023fea1f80710e6d7caa0b849fe060db32ba" alt=""
data:image/s3,"s3://crabby-images/efbbf/efbbfcc6e57caa36d445920a9cdd48b1603741a7" alt=""
data:image/s3,"s3://crabby-images/8deba/8deba285273ad12232b2de3216da1e488565a340" alt=""
data:image/s3,"s3://crabby-images/8fb7c/8fb7c087550b2467c009c28b2555c2b76dbfb6dd" alt=""
data:image/s3,"s3://crabby-images/1df1a/1df1ac9cbaceeca8e2f7fb00131d67b4fbf6dc06" alt=""
data:image/s3,"s3://crabby-images/b7f83/b7f83f82b92b2ddeb7ff9a8201e78e1d1a7397ee" alt=""
data:image/s3,"s3://crabby-images/1282d/1282db2c78feab483003c03a9f113c92bf763dbc" alt=""
data:image/s3,"s3://crabby-images/e45c6/e45c69ae8edefe910c26c17c07fd87671af19bb8" alt=""
控制台,全局作用域,全局变量和全局函数,事件处理机制以及事件环机制,怎么使用node.js框架中提供的调试工具。
请点赞!因为你的鼓励是我写作的最大动力!
吹逼交流群:711613774
data:image/s3,"s3://crabby-images/4c4bc/4c4bc5bd765d61bdab3f87543f4b86350cec2e05" alt=""