> 웹 프론트엔드 > JS 튜토리얼 > javascript_javascript 기술을 기반으로 WeChat 채팅 패널 만들기

javascript_javascript 기술을 기반으로 WeChat 채팅 패널 만들기

WBOY
풀어 주다: 2016-05-16 15:11:14
원래의
1954명이 탐색했습니다.

본 글의 예시는 위챗 채팅 패널을 자바스크립트로 만들기 위한 관련 코드를 공유하고 있으며, 구체적인 내용은 다음과 같습니다

먼저 사진부터 찍으세요

말하기 개체를 변경하려면 아바타를 클릭하세요. 구현 원리에 대해 간단히 이야기해 보겠습니다. 대화 내용은 모두 자바스크립트로 동적으로 생성됩니다.

가장 어려운 점: 먼저 CSS를 배치합니다. Obama가 보냈을 때 Li가 둥둥 떠 있게 놔두었습니다.

코드:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>模拟短信发送</title>
  <style>
    * {
      margin: 0;
      padding: 0;
      list-style: none;
      font-family: '微软雅黑'
    }
    #container {
      width: 450px;
      height: 780px;
      background: #eee;
      margin: 80px auto 0;
      position: relative;
      box-shadow: 20px 20px 55px #777;
    }
    .header {
      background: #000;
      height: 34px;
      color: #fff;
      line-height: 34px;
      font-size: 20px;
      padding: 0 10px;
    }
    .footer {
      width: 430px;
      height: 50px;
      background: #666;
      position: absolute;
      bottom: 0;
      padding: 10px;
    }
    .footer input {
      width: 275px;
      height: 45px;
      outline: none;
      font-size: 20px;
      text-indent: 10px;
      position: absolute;
      border-radius: 6px;
      right: 80px;
    }
    .footer span {
      display: inline-block;
      width: 62px;
      height: 48px;
      background: #ccc;
      font-weight: 900;
      line-height: 45px;
      cursor: pointer;
      text-align: center;
      position: absolute;
      right: 10px;
      border-radius: 6px;
    }
    .footer span:hover {
      color: #fff;
      background: #999;
    }
    #icon {
      display: inline-block;
      background: red;
      width: 60px;
      height: 60px;
      border-radius: 30px;
      position: absolute;
      bottom: 6px;
      left: 14px;
      cursor: pointer;
      overflow: hidden;
    }
    img {
      width: 60px;
      height: 60px;
    }
    .content {
      font-size: 20px;
      width: 435px;
      height: 662px;
      overflow: auto;
      padding: 5px;
    }
    .content li {
      margin-top: 10px;
      padding-left: 10px;
      width: 412px;
      display: block;
      clear: both;
      overflow: hidden;
    }
    .content li img {
      float: left;
    }
    .content li span{
      background: #7cfc00;
      padding: 10px;
      border-radius: 10px;
      float: left;
      margin: 6px 10px 0 10px;
      max-width: 310px;
      border: 1px solid #ccc;
      box-shadow: 0 0 3px #ccc;
    }
    .content li img.imgleft { 
      float: left; 
    }
    .content li img.imgright { 
      float: right; 
    }
    .content li span.spanleft { 
      float: left;
      background: #fff;
    }
    .content li span.spanright { 
      float: right;
      background: #7cfc00;
    }
  </style>
  <script>
    window.onload = function(){
      var arrIcon = ['img/1.jpg','img/2.jpg'];
      var num = 0;   //控制头像改变
      var iNow = -1;  //用来累加改变左右浮动
      var icon = document.getElementById('icon').getElementsByTagName('img');
      var btn = document.getElementById('btn');
      var text = document.getElementById('text');
      var content = document.getElementsByTagName('ul')[0];
      var img = content.getElementsByTagName('img');
      var span = content.getElementsByTagName('span');

      icon[0].onclick = function(){
        if(num==0){
          this.src = arrIcon[1];
          num = 1;
        }else if(num==1){
          this.src = arrIcon[0];
          num = 0;
        }        
      }
      btn.onclick = function(){
        if(text.value ==''){
          alert('发送内容不能为空');
        }else {
          content.innerHTML += '<li><img src="'+arrIcon[num]+'"><span>'+text.value+'</span></li>';
          iNow++;
          if(num==0){
            img[iNow].className += 'imgright';
            span[iNow].className += 'spanright';
          }else {
            img[iNow].className += 'imgleft';
            span[iNow].className += 'spanleft';
          }
          text.value = '';
        }
      }
    }
  </script>
</head>
<body>
  <div id="container">
    <div class="header">
      <span style="float: left;">白超华-博客园</span>
      <span style="float: right;">20:30</span>
    </div>
    <ul class="content"></ul>
    <div class="footer">
      <div id="icon">
        <img src="img/1.jpg" alt="">
      </div>
      <input id="text" type="text" placeholder="说点什么吧...">
      <span id="btn">发送</span>
    </div>
  </div>
</body>
</html>
로그인 후 복사

이 기사가 JavaScript 프로그래밍을 배우는 모든 사람에게 도움이 되기를 바랍니다.

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿