一、 需求分析

要求:作品实现本地存储和增删改查

由于当时没有规定作品必须写什么,所以这时候就是发挥创意,这里写了一个原神角色展示页面,在这个基础上结合作品要求,与官网页面有差距。

二、最终结果

三、代码实现

1. 由于用到了jQuery和Bootstrap,所以要先去官网引入相关标签

<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>

<script src="/原神/bootstrap1.min.js"></script>

因为我的Bootstrap是下载下来的,所以直接是本地路径,jQuery是引用网上的

2. HTML代码

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

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

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

<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>

<script src="/原神/bootstrap1.min.js"></script>

<link rel="stylesheet" href="/原神/bootstrap.min.css">

<title>《原神》官方网站-角色</title>

<link rel="stylesheet" href="gaunwang.css">

</head>

<body>

<div class="container">

<div class="header">

<div class="header-wrap">

<div class="header-wrap-left">

<ul>

<li>首页</li>

<li>新闻</li>

<li class="header-active" style="line-height: 56px;color: white;">角色</li>

<li>世界</li>

<li>漫画</li>

<li>社区</li>

</ul>

</div>

<div class="header-wrap-found">

<button class="btn btn-default btn-primary" data-toggle="modal" data-target="#myModel">增加</button>

<input type="text" id="found-person">

<button id="found">查找</button>

</div>

</div>

</div>

<div class="center">

<img src="/原神/jq_原神/璃月港.jpg" alt="">

<ul class="center-city">

<li>蒙德城</li>

<li id="center-active">璃月港</li>

<li>稻妻城</li>

<li>敬请期待</li>

</ul>

<ul class="center-porsen">

<li>

<img src="/原神/jq_原神/魈.png" alt="" id="big-picture">

<div class="big-name">

</div>

<div class="person-cv">

CV:

<div class="cv-name">

kinsen

</div>

<button class="btn btn-primary rev" data-toggle="modal" data-target="#myModal">修改</button>

<div class="revl">

点击修改角色cv

</div>

</div>

</li>

</ul>

<ul class="center-little">

<div class="little-list">

<li class="list">

<img src="/原神/jq_原神/小头像_魈.png" alt="" class="little-delet">

<div class="person-name">魈</div>

<button class="delet">删除</button>

</li>

</div>

</ul>

</div>

</div>

<!-- 添加的模态框 -->

<div class="modal fade" id="myModel" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">

<div class="modal-dialog">

<div class="modal-content">

<div class="modal-header">

<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>

<h4 class="modal-title" id="myModalLabel">增加信息</h4>

</div>

<div class="modal-body">

<form>

<div>

<input type="text" placeholder="角色名字" id="name" class="form-control" />

</div>

<div class="cv">

<input type="text" placeholder="CV" id="cv" class="form-control" />

</div>

</form>

</div>

<div class="modal-footer">

<button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>

<button type="button" class="btn btn-primary aad" data-dismiss="modal">增加信息</button>

</div>

</div>

<!-- /.modal-content -->

</div>

<!-- /.modal -->

</div>

<!-- 修改的模态框 -->

<div class="modal fade" id="myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">

<div class="modal-dialog">

<div class="modal-content">

<div class="modal-header">

<button type="button" class="close" data-dismiss="modal" aria-hidden="true">&times;</button>

<h4 class="modal-title" id="myModalLabel">修改信息</h4>

</div>

<div class="modal-body">

<form>

<div class="form-group">

<input type="text" placeholder="修改前的角色cv" id="reusr" class="form-control" />

</div>

<div class="form-group">

<input type="text" placeholder="修改后的角色cv" id="reusrnum" class="form-control" />

</div>

</form>

</div>

<div class="modal-footer">

<button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>

<button type="button" class="btn btn-primary olk" data-dismiss="modal">提交更改</button>

</div>

</div>

<!-- /.modal-content -->

</div>

<!-- /.modal -->

</div>

<script src="guanwang.js"></script>

</body>

</html>

3. css代码

body{

margin: 0;

padding: 0;

}

ul,li,ol{list-style-type: none;padding: 0;margin: 0;}

a{text-decoration: none;}

.container{

margin: 0;

width: 100%;

max-width: 100%;

padding: 0;

}

.header{

background-color: rgba(90, 90, 90,.6);

width: 100%;

height: 66px;

position: relative;

z-index: 4;

}

.header-wrap{

background-color: rgba(90, 90, 90,.6);

width: 100%;

height: 66px;

}

.header-wrap ul{

float: left;

display: flex;

}

.header-wrap ul li{

font-size: 20px;

font-weight: normal;

font-stretch: normal;

letter-spacing: 0px;

color: #ccc;

text-align: center;

cursor: pointer;

margin: 0 30px ;

height: 66px;

line-height: 66px;

}

.header-active{

border-top: 5px solid #69e0ff;

}

.header-wrap-found{

float: right;

margin: 15px 30px 0 0;

}

.header-wrap-found input{

background-color: rgb(194, 194, 194);

height: 30px;

line-height: 30px;

border-radius: 5px;

outline: none;

}

.header-wrap-found button{

background-color: rgb(194, 194, 194);

height: 35px;

line-height: 30px;

border-radius: 5px;

}

.center{

position: relative;

top: -70px;

bottom: 0;

left: 0;

right: 0;

}

.center img{

width: 100%;

height: 760px;

}

.center-city{

position: absolute;

top: 300px;

left: 40px;

position: absolute;

z-index: 9;

width: 370px;

height: 100%;

box-sizing: border-box;

height: 216px;

}

.center-city li{

padding-left: 30px;

cursor: pointer;

height: 54px;

line-height: 40px;

font-size: 18px;

color: #fff;

width: 100%;

background-repeat: no-repeat !important;

background-position: 20px 0 0 0;

background: url()  ;

}

#center-active{

width: 370px;

height: 54px;

line-height: 40px;

padding-left: 60px;

background: url();

}

.center-little{

display: flex;

position: absolute;

left: 0;

/* top: 0; */

bottom: 4px;

width: 100%;

height: 230px;

background-color: rgba(90, 90, 90,.4);

}

.center-little li img{

width: 106px;

height: 106px;

}

.person-name{

color: white;

font-size: 20px;

width: 106px;

height: 30px;

line-height: 30px;

text-align: center;

cursor: pointer;

}

.little-list{

width: 1000px;

margin: 0 auto;

box-sizing: border-box;

padding-top: 35px;

overflow-x: scroll;

}

.center-porsen{

position: absolute;

top: 0px;

left: 250px;

width: 1300px;

height: 100%;

}

.big-name{

position: absolute;

top: 200px;

left: 200px;

font-size: 80px;

color: white;

width: 400px;

height: 400px;

}

.person-cv{

position: absolute;

top: 350px;

left: 200px;

font-size: 30px;

border: 2px solid #f79b50;

background-color: #f3a86b;

width: 200px;

height: 50px;

line-height: 50px;

/* text-align: center; */

}

.cv-name{

width: 130px;

position: absolute;

top: 0px;

left: 70px;

}

.little-list li{

float: left;

margin-right: 40px;

}

.rev{

font-size: 16px;

position: absolute;

top: 60px;

left: 0;

}

.revl{

font-size: 18px;

color: white;

position: absolute;

left: 70px;

top: 55px;

}

.delet{

margin-left: 30px;

}

3. js代码

//本地存储数组

function getList() {

let data = localStorage.getItem('todolist');

if (data !== null) {

//本地存储的数据是字符串格式的,但是要转化对象格式

// console.log( JSON.parse(data));

return JSON.parse(data);

} else {

return [];

}

}

var flag = false;

//数组去重

function arrsa(newInput, flag) {

let data = getList();

for (let i = 0; i < data.length; i++) {

if (data[i].name == newInput) {

flag = true;

break;

}

}

return flag;

}

load();

//渲染

function load() {

let data = getList();

for (let i = 0; i < data.length; i++) {

if (data[i].disp == true) {

$(".big-name").text(data[i].name)

$(".cv-name").text(data[i].cv1)

$("#big-picture").attr("src", data[i].pot)

}

}

$(".little-list").empty();

$.each(data, function (i, n) {

$(".little-list").append(`<li id = ` + i + ` class="list">

<img src="/原神/jq_原神/小头像_`+ n.name + `.png" alt="" id = "little-person">

<div class="person-name">`+ n.name + `</div>

<button class="delet">删除</button>

</li>

`)

})

}

//保存本地存储的数据

function setDat(dat) {

localStorage.setItem('todolist', JSON.stringify(dat));

}

$(document).on("click", ".aad", function () {

let data = getList();

let inputname = $("#name").val();

let inputcv = $("#cv").val();

let littleImg = '/原神/jq_原神/小头像_' + inputname + '.png'

let imgUrl = "/原神/jq_原神/" + inputname + ".png";

if ($("#name").val().trim() !== '' && $("#cv").val().trim() != '' && !arrsa(inputname, flag)) {

// console.log('dsf');

data.push({

name: inputname,

cv1: inputcv,

pot: imgUrl,

litte: littleImg,

disp: false

})

}

setDat(data);

load();

})

//这是修改功能

$(document).on("click", ".olk", function () {

let data = getList();

// let oldCv = $("#reusr").val();

// console.log($("#reusr").val());

let newCv = $("#reusrnum").val();

if ($("#reusr").val().trim() !== '' && $("#reusrnum").val().trim() !== '') {

for (let i = 0; i < data.length; i++) {

if ($("#reusr").val() == data[i].cv1) {

data[i].cv1 = newCv;

break;

}

}

setDat(data);

load();

} else {

alert('输入值不能为空');

}

})

//这是删除功能

$(document).on("click", ".delet", function () {

// alert('被双击了');

let data = getList();

let m = $(this).index(".delet");

console.log(m);

data.splice(m, 1);

if (data[m].disp == true) {

for (let i = 0; i < data.length; i++) {

data[i].disp = false;

}

data[m - 1].disp = true;

$(".big-name").text(data[m - 1].name)

$(".cv-name").text(data[m - 1].cv1)

$("#big-picture").attr("src", data[m - 1].pot)

}

setDat(data);

load();

})

//点击将小头像显示为大图

$(document).on("click", ".list", function () {

// console.log(m);

let data = getList();

let m = $(this).index(".list");

for (let i = 0; i < data.length; i++) {

data[i].disp = false;

}

data[m].disp = true;

$(".big-name").text(data[m].name)

$(".cv-name").text(data[m].cv1)

$("#big-picture").attr("src", data[m].pot)

setDat(data);

load();

})

//查找功能

$(document).on("click", "#found", function () {

let data = getList();

// console.log($("#found-person").val());

for (let i = 0; i < data.length; i++) {

data[i].disp = false;

if (data[i].name == $("#found-person").val()) {

data[i].disp = true;

$(".big-name").text(data[i].name)

$(".cv-name").text(data[i].cv1)

$("#big-picture").attr("src", data[i].pot)

}

}

// $("#found-person").val() = ''

setDat(data);

load();

})

四、概述

1. 作品中需要的图片是从官网下载的

2. 页面不可以在“蒙德”和“璃月”或者“稻妻”之前切换,上面的导航栏也不能切换,原因是,作品不需要,另外时间紧张

3. 一点点题外话,我爱胡桃

jquery+Bootstrap作品实现教程相关推荐

  1. 禁用/启用按钮和链接的最简单方法是什么(jQuery + Bootstrap)

    本文翻译自:What is the easiest way to disable/enable buttons and links (jQuery + Bootstrap) Sometimes I u ...

  2. 25个非常棒的jQuery滑块插件和教程

    图像滑块和幻灯片效果,已成为网页设计的基本要素.它们以有趣的方式展示视觉内容.如果你一直想知道这是如何实现的,那么这里的25个非常棒的 jQuery 图片滑块制作教程将帮助您实现这种效果. 1.Cre ...

  3. 类操作是什么意思?jQuery的类操作教程分享

    类操作就是通过操作元素的类名进行元素样式操作,当元素样式比较复杂时,如果通过css()方法实现,需要在CSS里编写很长的代码,既不美观也不方便.而通过写一个类名,把类名加上或去掉就会显得很方便.下面通 ...

  4. 推荐40个简单的 jQuery 导航插件和教程【下篇】

    在这篇文章中,我为大家收集了40款非常棒的 jQuery 导航插件和教程.导航作为网站重要的组成部分,能够帮助用户找到他们想要的内容,因此导航设计的好坏决定了用户能够在你的网站停留更长的时间,浏览更多 ...

  5. 40个新鲜出炉的 jQuery 插件和免费教程【上篇】 转载自:梦想天空

    40个新鲜出炉的 jQuery 插件和免费教程[上篇] 转载于:https://www.cnblogs.com/chenjunLovefan/archive/2012/07/23/2605003.ht ...

  6. jQuery - Bootstrap 3 and Youtube in Modal

    1. 效果一 HTML <a href="#" class="btn btn-default" data-toggle="modal" ...

  7. 8个很棒的 jQuery 倒计时插件和教程

    jQuery 是最流行也是使用最广泛的 JavaScript 框架,它简化了 HTML 文档操作,事件处理,动画效果和 Ajax 交互.下面向大家分享8个优秀的 jQuery倒计时插件和教程. jQu ...

  8. jquery+bootstrap 创建日历表格

    jquery创建日历表格 jquery+bootstrap 创建日历表格 #写的不太好 欢迎留言赐教 <meta charset="utf-8"><meta na ...

  9. jQuery+Bootstrap美化弹出框

    项目中很多弹出的警告框是通过alert()弹出的浏览器警告框,样式比较丑陋且和页面使用的Bootstrap框架样式不吻合,因此需要修改弹出框样式. 采用jQuery+Bootstrap的方式这样弹出的 ...

  10. ie8浏览器的兼容性问题及解决(jquery,bootstrap)

    ie8浏览器的兼容性问题及解决(jquery,bootstrap) 参考文章: (1)ie8浏览器的兼容性问题及解决(jquery,bootstrap) (2)https://www.cnblogs. ...

最新文章

  1. 邮件系统三功能 建金字塔防护体系
  2. NSArray中存的是实体时的排序
  3. git如何合并指定文件内容_Git合并指定文件到另一个分支
  4. 在xml里追加结点时添加回车(libxml2)
  5. python是干什么的-python学来主要是干什么的
  6. Redis数据结构总结
  7. UE4官方文档踩坑:FPS示例2.7 UCameraComponent
  8. 人工智能、大数据和云计算之间,它们之间主要有什么关系?
  9. 字符识别引擎Calamari总结
  10. hdu3911 Black And White (线段树/区间合并)
  11. AMR-WB 比特流---单通道多帧,120ms RTP打包
  12. 升级glibc经验谈!!!
  13. 关于滑动时对背景动态高斯模糊的自定义控件
  14. MATLAB用梯度法求解目标函数,机械优化设计作业——梯度法求解
  15. 安徽计算机在职研究生学校,安徽在职研究生招生学校2020
  16. Python的学习(二十一)----Python的静态变量
  17. PHP学习----换行符
  18. java jsp 获得网页源代码三种方式
  19. f5 会话保持 负载均衡_F5会话保持的理解
  20. gnss、gps、imu、rtk、ins区分及含义

热门文章

  1. 正版NOD32升级ID在线申请
  2. VC+DirectShow对视频进行图片处理(转)
  3. 读取excel数据的方式整理
  4. 非常全面的IReport的使用
  5. 区块链技术的应用价值了解下
  6. python图片搜索_用Python构建图片处理搜索引擎
  7. 业务员如何听懂采购要吃回扣的暗语或者动作?
  8. 内核ppp编制和错误分析
  9. 计算机 分类号,中图法分类号(计算机,自动化)(CLC number (computer, automation)).doc...
  10. 句子反转:小米笔试编程题目——python