借助node.js + mysql 学习基础ajax~

很多小白不知道ajax怎么学,所以就弄了个node后台模拟下基本的ajax请求。

环境要求是安装node~

先上linkMysql.js


var mysql = require(‘mysql‘)
var connection = mysql.createConnection({
  host: ‘localhost‘,
  user: ‘root‘,
  password: ‘‘, //自己数据库的密码
  database: ‘‘//自己数据库的名称
})

function LinkMysql(tableName, key, value) {
  connection.connect()
  var data = ‘‘
  var sql = ‘SELECT * FROM ‘ + tableName +‘ where ‘ + key + ‘=‘ + value
  console.log(sql)
  return new Promise(function(resolve,reject) {
    connection.query(sql, function(err, result) {
      console.log(‘--------------------------SELECT----------------------------‘);
      console.log(result);
      console.log(‘------------------------------------------------------------\n\n‘);
      resolve(result)
    })
  })
}

function cutMysql() {
  connection.end();
}

module.exports = {
  cutMysql,
  LinkMysql
}

主JS server.js,提供连接maysql和不连接mysql两种版本


var http = require(‘http‘)
var url = require(‘url‘);
var util = require(‘util‘);
var sqlFunc = require(‘./linkMysql.js‘);

// 不连接数据库操作
// var tempJson = [{
//   name: ‘巧克力‘,
//   price: 10
// },{
//   name: ‘薯条‘,
//   price: 20
// }]

http.createServer(function(req, res) {
  // 跨域处理
  res.setHeader("Access-Control-Allow-Origin", "*");
  res.setHeader("Access-Control-Allow-Headers", "X-Requested-With");
  res.setHeader("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
  res.setHeader("X-Powered-By",‘ 3.2.1‘);
  res.setHeader("Content-Type", "application/json");

  var reqUrl = req.url
  var mainPath = reqUrl.split(‘?‘)[0]
  var reqData = reqUrl.split(‘?‘)[1].split(‘=‘)

  if (mainPath == ‘/test‘) {
    sqlFunc.LinkMysql(‘goods_info‘, reqData[0], JSON.stringify(decodeURIComponent(reqData[1]))).then(function(val) {
      console.log(‘从数据库获取数据‘ + val)
      sqlFunc.cutMysql();

      res.writeHead(200, {‘content-Type‘: ‘text/plain; charset=utf-8‘});
      res.end(JSON.stringify(val));
    })
    // 不连接数据库操作
    // res.writeHead(200, {‘content-Type‘: ‘text/plain; charset=utf-8‘});
    // res.end(JSON.stringify(tempJson));
  } else {
    res.writeHead(404, {‘content-Type‘: ‘text/plain; charset=utf-8‘});
  }

}).listen(3000);

console.log(‘Server running at http://localhost:3000‘);

最后就是前端html页面了~test.html,用了原生写法,具体的就不讲了百度一大堆~

```<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<meta name="viewport" content="width=device-width, initial-scale=1.0">

<meta http-equiv="X-UA-Compatible" content="ie=edge">

<title>Document</title>

</head>

<body>

<div>数据请求</div>

<div class="box">

</div>

<script>

var xhr = new XMLHttpRequest()

xhr.onreadystatechange = function(){
  if (xhr.readyState == 4) {
    if ((xhr.status &gt;= 200 &amp;&amp; xhr.status &lt; 300) || xhr.status == 304) {
      console.log(xhr.responseText)
      var data = JSON.parse(xhr.responseText)
      var str = ‘‘
      for(var i = 0; i &lt; data.length; i ++) {
        str += "&lt;div&gt;name: " + data[i].name + "&lt;/div&gt;&lt;div&gt;price: " + data[i].price + "&lt;/div&gt;"
      }
      document.querySelector(‘.box‘).innerHTML = str
    } else {
      console.log("Request was unsuccessful: " + xhr.status)
    }
  }
}

xhr.open(‘get‘, ‘http://localhost:3000/test?name=巧克力‘, true)
xhr.send(null)

</script>

</body>

</html>

```

命令行输入
node server.js 启动服务 刷新test.html页面就能拿到数据了~

来源:https://segmentfault.com/a/1190000016700988

原文地址:https://www.cnblogs.com/qixidi/p/10173624.html

时间: 2024-07-30 19:43:08

借助node.js + mysql 学习基础ajax~的相关文章

Node.js知识点学习

Node.js知识点学习 一.基本概念 Node.js,或者 Node,是一个可以让 JavaScript 运行在服务器端的平台.可以说,Node.js开创了javascript模块化开发的先河,早期的javascript需求都很简单,基本都是写成函数的,然后是面向过程的写法,后来慢慢的引入面向对象开发思想,再后来就慢慢写成 类.最后node.js的出现才开始有了js模块化开发的概念,这使得臃肿的js代码免去了命名冲突等一系列开发难题. Node最大的特点就是采用了异步式I/O与事件驱动的架构设

Node.js + MySQL 实现数据的增删改查

通过完成一个 todo 应用展示 Node.js + MySQL 增删改查的功能.这里后台使用 Koa 及其相应的一些中间件作为 server 提供服务. 初始化项目 $ mkdir node-crud && cd $_ $ yarn init -y && npx gitignore node 上面的命令创建了一个空文件夹 node-crud,进入之后初始化一个 package.json 以及创建 .gitignore 文件. 安装 Koa 并创建 app.js 以启动一个

Node.JS 学习路线图,Node.JS最佳学习资料

原文出处: 张丹的博客(@Conan_Z) Node.JS 让人心动的技术. 从零开始nodejs系列文章, 将介绍如何利Javascript做为服务端脚本,通过Nodejs框架web开发.Nodejs框架是基于V8的引擎,是目前速度最快的 Javascript引擎.chrome浏览器就基于V8,同时打开20-30个网页都很流畅.Nodejs标准的web开发框架Express,可以帮 助我们迅速建立web站点,比起PHP的开发效率更高,而且学习曲线更低.非常适合小型网站,个性化网站,我们自己的G

最新短视频网站实战教程 node.js+ES+Koa2基础到精通项目实战课程

下载地址:百度网盘下载 node.js+ES+Koa2项目实战课,课程目录很多,只展示了主要章节课程目录第1章 2018 年的编程姿势1-0 课前必看.mp41-1 koa2导学.mp41-2 安装跟进最新 node.js 版本.mp41-3 毫不犹豫的使用promise.mp41-4 使用babel 编译es7 async function.mp4 第2章 必会 ES6-7 语法特性与规范2-0 课前必读.mp42-1 生成器函数.mp42-2 co 库执行 promise 和 generat

实战 node.js+ES+Koa2基础到精通项目

node.js+ES+Koa2项目实战课,课程目录很多,只展示了主要章节课程目录第1章 2018 年的编程姿势1-0 课前必看.mp41-1 koa2导学.mp41-2 安装跟进最新 node.js 版本.mp41-3 毫不犹豫的使用promise.mp41-4 使用babel 编译es7 async function.mp4第2章 必会 ES6-7 语法特性与规范2-0 课前必读.mp42-1 生成器函数.mp42-2 co 库执行 promise 和 generator function.m

node.js入门学习

一.node.js介绍 1.1.node.js是什么 官网首页总结:Node.js® 是一个基于 Chrome V8 引擎 的 JavaScript 运行时. 1)node.js是一个开发平台,就像java开发平台..net开发平台.PHP开发平台.Apple开发平台一样. - 什么是开发平台:有对应的编程语言.有语言运行时.有能实现特定功能的API(SDK Software Development Kit) 2)node.js平台使用的编程语言是JavaScript. 3)node.js平台是

Node.JS + Mysql数据库

服务嘛,当然离不开数据库了,你要是见到数据就哭了,我建议你还是看看本文,不要做数据哭啊,哈哈哈 要做 '数据酷'嘛,哈哈哈 一 安装 1. wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm 2. yum -y install mysql57-community-release-el7-10.noarch.rpm 3. yum -y install mysql-community-serv

Node.js(一)——NodeJs基础

一.概念 node.js采用Google Chrome浏览器规范引擎 由C++语言编写的.本质上是一个JavaScript的运行环境 nodejs 不仅仅能解析js代码而且没有浏览器端各种安全的级别限制 还提供一些系统级别的API,比如: 1.文件的读写 2.进程的管理 3.网络的通信 09年面世以来一直很火 其次它很强,借助于NodeJs所能完成的事情,当然不仅仅与此 Node-Webkit appjs 相似的应用:允许开发者使用web技术,也就是html/css/js来开发跨平台的.桌面的应

Node.js 参考学习地址

前段时间研究过Node.js 自从由于笔记本硬盘崩了之后就很少在家里搞程序了,但是很想学习之,只因最近在努力学习英文.技术之外的事也需要做好,我们毕竟不是为了技术而生,技术是我们生存的一门得力技能,唯如此方能活得精彩而丰富.人需要有更多的追求,去看看大千世界,所谓读万卷书不如行万里路,如果没有经世之才,又何必去假装大师.所以在此感谢提供如下Node.js文献的作者. Node.js的本质:  http://forjs.org/book/lkaK8WuNme/section/gygez8oTBPg