App.vue
<script setup>
import HelloWorld from './components/HelloWorld.vue'
import Login from './components/Login.vue'
// import Calc from './components/Calc.vue'
// import ShoppingCart from './components/ShoppingCart.vue'
</script>
<script>
export default{
data(){
return{
};
},
components:{
Login,
// Calc,
// ShoppingCart,
}
}
</script>
<template>
<Login></Login>
<!-- <Calc></Calc> -->
<!-- <ShoppingCart></ShoppingCart> -->
</template>
<style scoped>
</style>
登录页面
<script>
export default{
data(){
return{
name:"",
pass:"",
};
},
methods:{
check:function(){
var name = this.name;
var pass = this.pass;
console.log(name+","+pass)
if (pass.length < 6 || pass.length > 18) {
alert("密码由6~18位的大小字母、数字、符号组成!")
} else if (name == "admin" && pass == "123456" || name == "admin2" && pass == "456789") {
alert("输入正确")
} else {
alert("用户名或密码错误!");
}
}
}
}
</script>
<template>
<form name="f" >
<h1>登录页面</h1>
<input type="text" id="name" placeholder="账号:admin" v-model="name"><br>
<input type="password" id="pass" placeholder="密码:123456" v-model="pass"><br>
<input type="button" @click="check()" value="登录">
<div id="divp">
<span>注册</span>
<span>忘记密码</span>
</div>
<p>© 2023 MrFlySand</p>
</form>
</template>
<style scoped>
h1{
line-height: 3em;
}
form {
text-align: center;
position: absolute;
/*表单于页面居中*/
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
padding: 0 40px;
background: #eff6ff;
padding: 20px 50px;
border-radius: 10px;
}
input[type=text],
input[type=password] {
background-color: rgba(0,0,0,0);
/*正常状态样式*/
color: black;
border: none;
outline: none;
text-align: center;
height: 50px;
width: 250px;
margin: 5px;
border-bottom: 1px solid #626262;
}
input[type=button] {
background-color: #45A0F2;
/*正常状态样式*/
color: white;
border: none;
border-radius: 20px;
outline: none;
text-align: center;
height: 50px;
width: 250px;
margin: 50px 5px 20px 5px;
}
input[type=button]:hover {
outline: none;
background-color: #348dde;
color: white;
}
#divp>span {
color: #348dde;
margin: 0 5px;
}
#divp span:active {
text-decoration: underline;
}
</style>
购物车
<script>
export default{
data(){
return{
selectAllValue:1,
priceSums:0,
push:{
name:null,
price:null,
count:null,
prices:null,
},
list:[{
checked:'false',
name:'微信公众号',
src:'https://mp.weixin.qq.com/mp/qrcode?scene=10000004&size=102&__biz=MzkzMjE5OTMwOA==&mid=2247487964&idx=1&sn=f7474b00c99bb7017530e4fbffd0c62d&send_time=',
introduce:'扫码关注,和群友们一起交流学习',
price:9999,
count:2,
prices:null,
},
{
checked:'false',
name:'QQ交流群',
src:'',
introduce:'',
price:6666,
count:1,
prices:null,
},
{
checked:'false',
name:'MacBookPro',
src:'https://img10.360buyimg.com/n2/jfs/t1/203950/20/28591/140129/637ca996E10cf6f5c/bb31749afd714364.jpg',
introduce:'',
price:21488,
count:1,
prices:null,
}],
}
},
computed:{
// 计算总和
priceSums:function(){
var sum = 0;
for(var i = 0; i != this.list.length; i++){
if(this.list[i].checked == true){
sum = sum + this.list[i].price * this.list[i].count;
}
}
return sum;
}
},
methods:{
//减少物品个数
reduce:function(index){
this.list[index].count = this.list[index].count - 1;
if(this.list[index].count == -1){
this.list.splice(index,1)
}
},
// 增加物品个数
add:function(index){
this.list[index].count = this.list[index].count + 1;
return "this.list[index].count";
},
// 添加新元素在购物车中
pushValue:function(){
console.log(this.push.name)
if(this.push.name == undefined) return 0;
for(var i=0; i<this.list.length; i++){
if(this.list[i].name == this.push.name){
alert("你已勾选此产品");
return 0;
}
}
this.list.push(this.push);
this.push = {name:'', price:null, count:null};
},
// 选中所有
selectAll:function(){
for(var i=0,j=0; i<this.list.length; i++){
if(this.list[i].checked == true){
if(i==j){
for(var k=0; k<this.list.length; k++){
this.list[k].checked = false;
}
this.selectAllValue = false;
return 0;
}
j++;
}
this.list[i].checked = true;
}
this.selectAllValue = true;
},
// 删除选中
selectDel:function(){
if(confirm("你确认要删除吗?","提示框 ")){
for(var i=0; i<this.list.length; i++){
if(this.list[i].checked == true){
this.list.splice(i,1);
}
}
}
},
// 搜索
// str.replace(/\ +/g,"") 清除空格
search:function(){
var str = "aaabc"
console.log(str.includes("d"))
var str = this.searchText.replace(/\ +/g,"")
for(var i=0; i<this.list.length; i++){
var nowStr = this.list[i].name.replace(/\ +/g,"");
if(str==nowStr || nowStr.includes(str)){
this.list.unshift(this.list[i]);
this.list.splice(i+1,1);
}
}
}
}
}
</script>
<template>
<table id="ShoppingCart">
<div id="search">
<input id="searchText" v-model="searchText" type="text" placeholder="搜索" >
<button @click="search">搜索</button>
</div>
<!-- 表头 -->
<tr style="font-weight: 800;">
<td>序号</td>
<td>商品</td>
<td>单价(元)</td>
<td>数量</td>
<td>金额(元)</td>
</tr>
<!-- 商品表 -->
<tr v-for="(value,index) in list">
<td><input type="checkbox" v-model="value.checked"></td>
<td>
<img v-bind:src="value.src" alt="图片" id="commodityImg">
<span>{{value.name}}</span>
<span style="font-size: 0.8em; color: #919191;">{{value.introduce}}</span>
</td>
<td style="color: #e00000;">¥{{ value.price }}</td>
<td style="padding: 0 !important;">
<button @click="reduce(index)">-</button>
<input type="text" v-model="value.count">
<button @click="add(index)">+</button>
</td>
<td style="color: #e00000;font-weight: 800;">¥{{value.price*value.count}}</td>
</tr>
<!-- 添加商品 -->
<tr id="add">
<td></td>
<td><input type="text" v-model="push.name" placeholder="商品"></td>
<td><input type="text" v-model="push.price" placeholder="价格"></td>
<td><input type="text" v-model="push.count" placeholder="数量"></td>
<td><button id="push" @click="pushValue">添加</button></td>
</tr>
<!-- 全选、删除、合计等操作 -->
<tr>
<td colspan="2">
<div @click="selectAll" ><input type="checkbox" v-model="selectAllValue">全选</div>
<div @click="selectDel" > 删除</div>
</td>
<td colspan="3">
合计:<p style="color: #e00000;font-weight: 800;padding: 0.6em 0em; display: contents;">¥{{priceSums}}</p></td>
</tr>
</table>
</template>
<style>
*{
padding: 0; margin: 0;
}
button{
/* margin-bottom: 10px !important; */
/* border:1px solid #ccc; */
width: 100%;
height:100%;
margin:0;
padding: 0;
border-radius: 0px;
}
#commodityImg{
border:1px solid #000;
margin-right:10px;
}
table{
border:none;
border-block: 4px solid #ccc;
writing-mode: horizontal-tb;
font-size: 1rem;
}
tr>td{
border:1px solid #fff;
padding:15px 10px;margin: 0;
height: 40px !important;
}
tr>td:nth-child(2){
width: 400px;
}
tr>td:nth-child(2)>img{
width: 100px;
float: left;
display: block;
}
tr>td:nth-child(2)>span{
display: flex;
}
tr>td:nth-child(4)>button,tr>td:nth-child(4)>input{
width: 60px;height: 30px;
border: none;
}
tr:last-child>td>div{
display: inline;
float: left;
margin:0;padding:0 !important;
}
tr{
padding:10px 20px;
display: block;
border-block-start:2px solid #ccc;
writing-mode: horizontal-tb;
}
#push{
margin: 0px !important;
width: 100%;
display: block;
border: none;
padding: 3px 15px;
}
input{
border: none;
text-align: center;
}
#add{
font-weight: 800 !important;
}
#add input{
height: 100%;
border:1px solid #ccc;
}
#add input:active{
border:1px solid #ccc !important;
}
#search{
border: #000 solid 1px;
padding: 0 !important;
margin: 20px 0;
}
#searchText{
margin: 2px 8px !important;
font-size: 16px;
}
#search input{
width: 90%;
padding: 5px 8px;
border: none !important;
user-select: none;
outline: none;
}
#search button{
width:auto;
padding: 5px 8px;
outline: none;
float: right;
border: none;
margin: auto 0;
}
#search button:active{
background-color: #ddd;
}
</style>
计算器
<script>
export default{
data(){
return{
sumValue:"0",
arr:[["x<sup>2</sup>","1/x","C","✖"],[7,8,9,"/"],[4,5,6,"*"],[1,2,3,"-"],[".",0,"=","+"]]
};
},
methods:{
getSum:function(index,i){
console.log(index+":"+i)
if(index==0 && i==0){
console.log(Math.pow(this.sumValue,2));
this.sumValue = Math.pow(this.sumValue,2);
}else if(index==0 && i==1){
console.log(this.sumValue)
this.sumValue = 1.0/this.sumValue;
}else if(index==0 && i==2){
this.sumValue = 0;
}else if(index==0 && i==3){
this.sumValue = this.sumValue.substring(0, this.sumValue.length - 1);;
}else if(index==4 && i==2){
this.sumValue = "结果:"+eval(this.sumValue);
}else if(this.sumValue == '0' || this.sumValue[0]=="结"){
this.sumValue = this.arr[index][i].toString();
}else if(this.sumValue != '0' && this.arr[index][i].toString()!="="){
this.sumValue = this.sumValue + this.arr[index][i].toString();
}
},
}
}
</script>
<template>
<table id="calc">
<tr>
<td colspan="4" style="padding: 0">
<input type="text" v-model="sumValue">
</td>
</tr>
<tr v-for="(value,index) in arr" :key="value">
<td v-for="(val,i) in value" :key="val" @click="getSum(index,i)" @keyup.enter="print(index,i)" v-html="val"></td>
</tr>
</table>
</template>
<style>
*{
padding: 0;margin: 0;
}
table{
/* border: 2px solid #000; */
user-select: none;
background-color: #eeeeee;
}
table td{
/* border: 1px solid #000; */
padding: 3px 16px;
background: #fff;
}
table td:hover{
background-color: #eee;
}
table td:active{
background-color: #ddd;
}
table tr:nth-child(1) td:hover{
background-color: #fff;
}
input{
border: none;
padding-top: -10px;
text-align: right;
outline: none;
}
</style>