【问题标题】:Need help using JQuery in Nodejs and Express在 Nodejs 和 Express 中使用 JQuery 需要帮助
【发布时间】:2018-07-22 01:45:59
【问题描述】:

我正在尝试制作一个简单的 Nodejs/Express 应用程序,该应用程序将在单击 SHOW 按钮时显示海滩图像,然后在再次单击 SHOW 按钮时显示湖泊图像。

它是一个简单的 js 应用程序,但我是第一次尝试 Nodejs 和 Express。

海滩和湖泊的照片存储在我的应用程序的图像文件夹中。 这是我的代码

app.js

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var cookieParser = require('cookie-parser');
var logger = require('morgan');

var indexRouter = require('./routes/index');
var usersRouter = require('./routes/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', indexRouter);
app.use('/users', usersRouter);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  next(createError(404));
});

// error handler
app.use(function(err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

index.js

var express = require('express');
var router = express.Router();

/* GET home page. */
router.get('/', function(req, res, next) {
  res.render('index', { title: 'Express' });
});

module.exports = router;

users.js

var express = require('express');
var router = express.Router();

/* GET users listing. */
router.get('/', function(req, res, next) {
  res.send('respond with a resource');
});

module.exports = router;

index.pug

extends layout

block content


  h1= title
  h4= "Click button below to see a photo of a beach"

  <form id="show">
    <button type="submit" class="btn btn-primary btn-margin">Show</button>
  </form>

  <div id="img">

  </div>

  <div class="image1">
    <img src="img/beach-pic.jpg" alt="photo of beach" id="img1">
    <img src="img/lake-pic.jpg" alt="photo of lake" id="img2">
  </div>

javascript/jquery

$(document).ready(function(){
  $("form#show").submit(function(){
    event.preventDefault();

    $("#img1").toggle();
    if($("#img1").css('display') == 'inline'){
      $("#img2").hide();
    } else {
      $("#img2").show();
    }
  });
});

css

body {
  padding: 50px;
  font: 14px "Lucida Grande", Helvetica, Arial, sans-serif;
}

a {
  color: #00B7FF;
}

#img1 {
  display: none;
}

#img2 {
  display: none;
  height: 500px;
  width: 650px;
}

【问题讨论】:

  • 无图像->单击“显示”->图像一->单击“显示”->图像二->单击“显示”->图像一等等...是这就是你要找的东西?
  • @Dhaval Jardosh:是的!
  • 已添加答案,如果您正在寻找,请告诉我。

标签: javascript jquery node.js


【解决方案1】:

对两个图像使用display:none,并在需要时切换。

唯一的事情就是处理你的第一张图片的展示,我们已经通过第一条 if-else 语句完成了。

$(document).ready(function() {
  $("#show").submit(function(event) {
    event.preventDefault();

    //Handle 1st Image Render
    if ($("#img1").css('display') == 'none' && $("#img2").css('display') == 'none') {
      $("#img1").css('display', 'block');
    }


    //Toggle After 1st render
    else if ($("#img1").css('display') == 'block') {
      $("#img2").css('display', 'block');
      $("#img1").css('display', 'none');
    } else if ($("#img2").css('display') == 'block') {
      $("#img1").css('display', 'block');
      $("#img2").css('display', 'none');
    }


  });
});
#img1,
#img2 {
  display: none;
  width: 200px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form id="show">
  <button id="lol" class="btn btn-primary btn-margin">Show</button>
</form>
<div id="img">

</div>

<div class="image1">
  <img src="https://images.pexels.com/photos/248797/pexels-photo-248797.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=350" alt="photo of beach" id="img1">
  <img src="https://images.pexels.com/photos/247600/pexels-photo-247600.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=350" alt="photo of lake" id="img2">
</div>

【讨论】:

  • 我进行了必要的更改,但仍然无法正常工作。以下是 Azure 上托管应用程序的链接:myexpressapp-angryfaiza.azurewebsites.net
  • 请检查图像,图像的路径是否正确。 myexpressapp-angryfaiza.azurewebsites.net/… - 告诉我你能在这里看到什么
  • 我现在使用与您的示例相同的图像链接,因此它们应该可以工作。该应用程序在 localhost 上运行良好,只是在 azure 中没有
  • 所以请检查您的数据库中的图像。
【解决方案2】:

一切看起来都很好,它现在到底在做什么?您的图像是否显示在页面上?您的 Node 端点是否正常工作?

【讨论】:

  • 页面上根本没有显示任何图像。该按钮根本不起作用。
  • 我认为是因为我的按钮没有连接到 jquery
【解决方案3】:

我不知道你的布局中有什么,但我认为一个可能的错误是你可能没有在你的 pug 文件中包含 jQuery 或 JavaScript 文件,因为我试图运行一个非常相似的代码并且它运行对我来说完全没问题。另一个可能的错误是包含两者的顺序,请确保先包含 jQuery,然后再包含您的 js 文件。如果仍然无法正常工作,请检查您的控制台是否有任何潜在错误,这通常会有所帮助。

【讨论】:

  • 你能告诉我如何在 index.pug 中包含 JQuery 和 JavaScript 文件吗?
猜你喜欢
  • 1970-01-01
  • 2012-12-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多