使用ruby搭建简易的http服务和sass环境
使用ruby搭建简易的http服务和sass环境
由于在通常的前端开发情况下,我们会有可能需要一个http服务,当然你可以选择自己写一个node的http服务,也比较简单,比如下面的node代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | var PORT = 3000; var http = require( 'http' ); var url=require( 'url' ); var fs=require( 'fs' ); var mine= { "css" : "text/css" , "gif" : "image/gif" , "html" : "text/html" , "ico" : "image/x-icon" , "jpeg" : "image/jpeg" , "jpg" : "image/jpeg" , "js" : "text/javascript" , "json" : "application/json" , "pdf" : "application/pdf" , "png" : "image/png" , "svg" : "image/svg+xml" , "swf" : "application/x-shockwave-flash" , "tiff" : "image/tiff" , "txt" : "text/plain" , "wav" : "audio/x-wav" , "wma" : "audio/x-ms-wma" , "wmv" : "video/x-ms-wmv" , "xml" : "text/xml" }; var path=require( 'path' ); var server = http.createServer(function (request, response) { var pathname = url.parse(request.url).pathname; console.log(pathname) var realPath = pathname.substr(1); //path.join("assets", pathname); console.log(realPath); var ext = path.extname(realPath); ext = ext ? ext.slice(1) : 'unknown' ; fs.exists(realPath, function (exists) { if (!exists) { response.writeHead(404, { 'Content-Type' : 'text/plain' }); response.write( "This request URL " + pathname + " was not found on this server." ); response.end(); } else { fs.readFile(realPath, "binary" , function (err, file) { if (err) { response.writeHead(500, { 'Content-Type' : 'text/plain' }); response.end(err); } else { var contentType = mine[ext] || "text/plain" ; response.writeHead(200, { 'Content-Type' : contentType }); response.write(file, "binary" ); response.end(); } }); } }); }); server.listen(PORT); console.log( "Server runing at port: " + PORT + "." ); |
但这个比较麻烦就是每次都要把这个文件copy到项目目录下,而且安装sass环境也是需要ruby的,所以我们有必要了解下gem安装sass 和asdf.
先导官网下载个ruby ,安装完之后就可以使用
gem install sass
命令安装其他组件了,比如要装sass环境.如果要安装beta版本的,可以在命令行中输入
gem install sass --pre
升级命令是
1 | gem update sass |
今天我们要装asdf这么个http服务,首先我们使用
1 | gem install asdf |
安装完成之后就可以在你需要访问的文件夹目录使用
1 | asdf -p 8080 |
然后就会出现如下图所示:
然后你就可以使用 http://localhost:8080/ 来访问当前目录的http服务了。
由于国内网络原因,有可能导致 rubygems.org 存放在 Amazon S3 上面的资源文件间歇性连接失败。这时候我们可以通过gem sources
命令来配置源,先移除默认的https://rubygems.org
源,然后添加淘宝的源https://ruby.taobao.org/
,然后查看下当前使用的源是哪个,如果是淘宝的,则表示可以输入sass安装命令gem install
了。
1 2 3 4 5 6 7 8 | $ gem sources --remove https: //rubygems.org/ $ gem sources -a https: //ruby.taobao.org/ $ gem sources -l *** CURRENT SOURCES *** https: //ruby.taobao.org # 请确保只有 ruby.taobao.org $ gem install sass |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架