分享好友 编程语言首页 频道列表

nodejs 模板引擎

nodejs文章/教程  2023-02-08 22:120

自制替换模板

template.js  

var fs = require('fs')
var http = require('http')


var server = http.createServer()
var wwwDir = 'D:/vuejs/nodejs/day2'

server.on('request', function (req, res) {
	var url = req.url
	

	fs.readFile('./template.html', function ( err, data ) {
		if (err) {
			return res.end('404 Not fount!!!!')
		}

		//1. 得到路径下所有文件名和目录名
			//fs.readdir('路径',function (err, data) {})
		//2. 将得到的文件名和目录名替换到template.html中
			//2.1 在template.html 中需要替换的位置预留特殊标记
			//2.2 根据 files 生成 Html 内容
		fs.readdir(wwwDir, function (error , files) {
			if (error) {
				return res.end('Can not find www dir.')
			}
			var content = ''
			files.forEach(function (item) {
				 content += `
				 	<tr>
						<td>${item}</td>
						<td>删 | 改</td>
					</tr>
				 `
			})
			data = data.toString()
			//console.log(data.replace( 'replacestring', content ));
			data = data.replace( 'replacestring', content )
			res.end( data )
		})

		
	})
})


server.listen(3000, function () {
	console.log('runing.....')
})

  

template.html

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>213</title>
</head>
<body>
	<table>
		<tr>
			<td>文件名</td>
			<td>操作</td>
		</tr>
		replacestring
	</table>
</body>
</html>

 

ART-TEMPLATE 模板

 github 网址:      https://aui.github.io/art-template/docs/installation.html

安装 :

npm install art-template --save

使用:

  1. 在需要使用的文件模块中加载 art-template

  2. 只需要使用 require 方法加载就可以了: require('art-template')

var template = require('art-template')
var fs = require('fs')
var http = require('http')

var server = http.createServer()
server.on('request', function (req, res) {
	var url = req.url

	var tplStr = fs.readFile( './tplStr.html', function (err, data) {

		if (err) {
			res.end(err)
		}

		data = data.toString()
		var ret = template.render( data , {
			name: 'Jason',
			age : 18,
			province: '北京市',
			hobbies: ['写代码','唱歌','打游戏']
		})

		res.end(ret)
	})

})


server.listen(3000, function () {
	console.log('runing.....')
})

  

tplStr.html  页面代码

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>tplStr</title>
</head>
<body>
	<p> 大家好, 我叫 {{ name }}, </p>
	<p> 我今年 {{ age }} 岁了, </p>
	<p> 我来自 {{ province }}, </p>
	<p> 我喜欢 {{ each hobbies }} {{ $value }} {{ /each }} </p>
</body>
</html>

 

例子2:  

 

文件夹:
    heedback
    ---public
    -----css
    -----img
    -----js
    -----lib
    ---views
    -----index.html
    -----post.html
    -----404.html
    ---app.js

  

app.js  代码

var http = require('http')
var fs   = require('fs')
var template = require('art-template')
var url  = require('url')

var comments = [
	{
		name: '张三',
		message: '今天天气不错',
		dateTime: '2019-10-16'
	},
	{
		name: '张三2',
		message: '今天天气不错',
		dateTime: '2019-10-16'
	},
	{
		name: '张三3',
		message: '今天天气不错',
		dateTime: '2019-10-16'
	},
	{
		name: '张三4',
		message: '今天天气不错',
		dateTime: '2019-10-16'
	},
	{
		name: '张三5',
		message: '今天天气不错',
		dateTime: '2019-10-16'
	}
]


http
	.createServer(function (req, res) {
		//使用 url.parse 方法将路径解析为一个方便操作的对象, 第二个参数为true 将查询字符串转为对象
		var parseObj = url.parse(req.url, true)
		//var url = req.url
		//单独获取不包含查询字符串的路径部分
		var pathname = parseObj.pathname

		if (pathname === '/') {
			fs.readFile('./views/index.html', function (err, data) {
				if ( err ) {
					return res.end('404 Not Found.')
				}
				var htmlStr = template.render( data.toString(), {
					comments: comments
				})
				res.end(htmlStr)
			})
		} else if ( pathname === '/post' ) {
			fs.readFile('./views/post.html', function (err, data) {
				if (err) {
					return res.end('404 Not found.')
				}
				res.end(data)
			})
		} else if ( pathname.indexOf('/public/') === 0 ) {
			// /public/css/main.css

			// 统一处理:
			// 		如果请求路径是以 /public/ 开头的,则我认为你要获取 public 中的某资源
			// 		把请求路径当文件路径来直接进行读取
			fs.readFile( '.' + pathname, function (err, data) {
				if ( err ) {
					return res.end('404 Not Found')
				}
				res.end(data)
			})

			
			
		} else if ( pathname === '/pinglun' ) {

			//console.log( parseObj )
			//res.end(JSON.stringify(parseObj.query))

			var comment = parseObj.query
			comment.dateTime = '2019-11-02 17:17:17'
			//comments.push(comment)
			comments.unshift(comment)

			//服务器让客户端重定向
			//	1. 状态码设置为302 临时重定向
			//		statusCode
			//	2. 在响应投中通过 Location 告诉客户端往哪重定向
			//		setHeader
			res.statusCode = 302
			res.setHeader( 'Location', '/' )
			res.end()

		} else {
			fs.readFile('./views/404.html', function (err, data) {
				if (err) {
					return res.end('404 Not found.')
				}
				res.end(data)
			})
		}

	})
	.listen(3000, function () {

		console.log('running....')

	})

 

views/index.html  代码

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>留言本</title>
  <!-- 
    浏览器收到 HTML 响应内容之后,就要开始从上到下依次解析,
    当在解析的过程中,如果发现:
      link
      script
      img
      iframe
      video
      audio
    等带有 src 或者 href(link) 属性标签(具有外链的资源)的时候,浏览器会自动对这些资源发起新的请求。
   -->
   <!-- 
      注意:在服务端中,文件中的路径就不要去写相对路径了。
      因为这个时候所有的资源都是通过 url 标识来获取的
      我的服务器开放了 /public/ 目录
      所以这里的请求路径都写成:/public/xxx
      / 在这里就是 url 根路径的意思。
      浏览器在真正发请求的时候会最终把 http://127.0.0.1:3000 拼上

      不要再想文件路径了,把所有的路径都想象成 url 地址
    -->
  <link rel="stylesheet" href="/public/lib/bootstrap/bootstrap.css">
</head>

<body>
  <div class="header container">
    <div class="page-header">
      <h1>Example page header <small>Subtext for header</small></h1>
      <a class="btn btn-success" href="/post">发表留言</a>
    </div>
  </div>
  <div class="comments container">
    <ul class="list-group">
      {{each comments}}
      <li class="list-group-item">{{ $value.name }}说:{{ $value.message }} <span class="pull-right">{{ $value.dateTime }}</span></li>
      {{/each}}
    </ul>
  </div>
</body>

</html>

  

views/post.html  代码

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <link rel="stylesheet" href="/public/lib/bootstrap/bootstrap.css">
</head>

<body>
  <div class="header container">
    <div class="page-header">
      <h1><a href="/">首页</a> <small>发表评论</small></h1>
    </div>
  </div>
  <div class="comments container">
    <!-- 
      以前表单是如何提交的?
      表单中需要提交的表单控件元素必须具有 name 属性
      表单提交分为:
        1. 默认的提交行为
        2. 表单异步提交

        action 就是表单提交的地址,说白了就是请求的 url 地址
        method 请求方法
            get
            post
     -->
    <form action="/pinglun" method="get">
      <div class="form-group">
        <label for="input_name">你的大名</label>
        <input type="text" class="form-control" required minlength="2" maxlength="10" >
      </div>
      <div class="form-group">
        <label for="textarea_message">留言内容</label>
        <textarea class="form-control" name="message" ></textarea>
      </div>
      <button type="submit" class="btn btn-default">发表</button>
    </form>
  </div>
</body>

</html>

  

views/404.html 代码

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
</head>
<body>
  <h1>抱歉!  您访问的页面失联啦...</h1>
</body>
</html>

  

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 



查看更多关于【nodejs文章/教程】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多热点专题
更多推荐文章
打造自己的 nodejs 静态文件服务器(帖子内容,直接复制别人的)
用NodeJS打造你的静态文件服务器在《The Node Beginner Book》的中文版(http://nodebeginner.org/index-zh-cn.html)发布之后,获得国内的好评。也有同学觉得这本书略薄,没有包含进阶式的例子。@otakustay同学说:“确实,我的想法是在这之上补一个简单的MV

0评论2023-02-10548

NodeJS无所不能:细数10个令人惊讶的NodeJS开源项目
在几年的时间里,NodeJS逐渐发展成一个成熟的开发平台,吸引了许多开发者。有许多大型高流量网站都采用NodeJS进行开发,像PayPal,此外,开发人员还可以使用它来开发一些快速移动Web框架。  除了Web应用外,NodeJS也被应用在许多方面,本文盘点了NodeJS在其

0评论2023-02-10598

Linux环境下的Nodejs linux安装基本环境
最近在学习Node.js,在window下总是觉得不那么爽快。最简单而且环保的方法是在虚拟机中安装一个Linux。 { 1.Linux:家中的Linux为Centos。 2.VirtuallyBox: 开启2块网卡。第一个选Host-Only目的是为了让虚拟机通上网。第二块选Bridge Adapter,这是为了

0评论2023-02-09597

nodejs package.json说明
{"name": "test", //项目名称(必须),由小写英文字母、数字和下划线,不能含空格"version": "1.0.0", //项目版本(必须)"description": "This is for study gulp project !", //项目描述(必须)"homepage": "", //项目主页url " key

0评论2023-02-09473

017 nodejs取参四种方法req.body,req.params,req.param,req.body
摘要: nodejs取参四种方法req.body,req.params,req.param,req.body 获取请求很中的参数是每个web后台处理的必经之路,nodejs提供了四种方法来实现。获取请求很中的参数是每个web后台处理的必经之路,nodejs的 express框架 提供了四种方法来实现。req.bodyre

0评论2023-02-09446

nodejs查看本机hosts文件域名对应ip
const dns = require('dns')dns.lookup('domainName', function(err, result) {console.log(result)}) related:https://***.com/questions/36689536/how-to-resolve-hostname-to-an-ip-address-in-node-js

0评论2023-02-09475

nodejs工程拷贝后运行报module找不到问题
工程文件夹通过复制黏贴到另外一个地方,运行后报错 “can`t find module 某某某”,查看原因:输入node 进入控制台,输入console.log(module.paths)查看当前nodejs查找module的路径,如果没有工程里的node_modules,通过module.paths.push加入,检查是否有效

0评论2023-02-09947

C# Socket TCP Server & Client & nodejs client cctv5体育节目表
要调试公司某项目里的一个功能,因为要准备测试环境,趁这个机会重温了一下Socket(全还给老师了 -_-#),做个备份。C# Serverstatic void Main(string[] args){int port = 81;string host = "192.168.1.151";//创建终结点IPAddress ip = IPAddress.Parse(hos

0评论2023-02-09810

nodejs微信公众号快速开发|自定义关键字回复
一点说明:nodejs 微信api 扩展,集成大部分功能。案例https://github.com/leiroc/node-wxeasy-example 上传example中文件到服务器 ,然后 npm install 成功https://github.com/leiroc/node-wxeasy-exampleBUG and NEWS增加客户功能增加模板消息增加扫描带参数

0评论2023-02-09404

Centos 32位 安装 NodeJS
yum -y install gcc make gcc-c++ openssl-devel wget下载源码及解压:wget https://nodejs.org/dist/v6.9.5/node-v6.9.5.tar.gztar -zvxf node-v0.10.26.tar.gz编译及安装:cd node-v0.10.26 切换目录,执行./configuremakemake install验证是否安装配置成功

0评论2023-02-09537

nodejs一部分基本模块及作用 node 引入一个模块的过程是什么
收集了NodeJS开发中常用的一些模块。MVC框架 -ExpressExpress 是轻量灵活的Nodejs Web应用框架,它可以快速地搭建网站。Express框架建立在Nodejs内置的Http模块上,并对Http模块再包装,从而实际Web请求处理的功能。它支持多种前端模板,如Jade, EJS等。它是T

0评论2023-02-09868

nodejs定时启动程序 nodejs开机自启
npm install node-schedule# 或yarn add node-schedule使用(second、minute、hour、  date、dayOfWeek、month、year)每分钟第1秒执行一次const schedule = require("node-schedule");var rule = new schedule.RecurrenceRule();rule.second = 1;// 秒schedu

0评论2023-02-09406

更多推荐