[0510] TIL 19일차

nikevapormax·2022년 5월 10일
0

TIL

목록 보기
18/116

😂 [팀플] 인스타그램 클론코딩

😭 메인피드 댓글달기 javascript 작성

  • 인스타그램의 메인피드에 보면 댓글을 달 수 있는 부분이 존재한다. 해당 부분에서 댓글을 달 수 있도록 javascript를 작성하였다. 해당 부분에서 작성한 댓글은 같은 모달에 존재하는 다른 댓글들과 마찬가지로 db에 저장되게 된다.
// ㅡㅡㅡㅡㅡㅡㅡ메인 피드에서 직접 댓글달기(댓글 더보기 x)ㅡㅡㅡㅡㅡㅡㅡㅡ
function save() {
    let comment = $("#input_comment").val();

    $.ajax({
        type: 'POST',
        url: '/comment',
        data: {cm_give: comment},
        success: function (response) {
            window.location.reload();
        }
    });
}

😭 마이페이지에 사용자의 아이디 및 정보 반영

  • GET 메서드를 통해 마이페이지에 있는 사용자의 아이디와 이름을 가져와 반영시켰다. 또한 사용자가 게시한 게시글의 개수를 list로 받아와 길이를 재 반영해 주었다. (팔로잉/팔로워 아직 미정)
  • 금일 진행한 것들 가운데 정말 핵심인 부분은 token 값을 사용한 사용자의 아이디 반영이다.
@app.route("/mypage/user", methods=["GET"]) # user_info + post + 프로필사진!!!!!!!!!!!!!!!
def prof_output():  # 회원정보에서 아이디와 이름을 받아오고, 이름을 프로필에 보여줌(아이디는 신원 확인용)
	token_receive = request.cookies.get('mytoken')
	payload = jwt.decode(token_receive, SECRET_KEY, algorithms=['HS256'])

	profile_id = db.user_info.find_one({"insta_id": payload["id"]})['insta_id']
	user_info_list = list(db.user_info.find({}, {'_id': False}))
	post_list = list(db.post_info.find({}, {'_id': False}))
	print(post_list)
	# follow, following 에서도 숫자 받아와야지 len
	return jsonify({'result': 'success','profile_id': profile_id,'user_info_list': user_info_list, 'post': post_list})
function show_insta_id() {
    $.ajax({
        type: 'GET',
        // 경로 설정에서 자꾸 에러가 발생해 mypage 뒤에 경로를 하나 더 추가해주었다.
        url: '/mypage/user',
        data: {},
        success: function (response) {
            const user = response['user_info_list']
            const id = response['profile_id']
            let name = ``
            for (let i=0; i < user.length; i++) {
                if (id === user[i]['insta_id']) {
                    name = user[i]['name']
                }
            }
            const post = response['post'].length

            let temp_html = `<div class="user_id">${id}</div>
                                  <div>
                                      <div class="state">
                                          <div><a class="state_num" href="">게시물 ${post}</a></div>
                                          <div><a class="state_num" href="">팔로워 251</a></div>
                                          <div><a class="state_num" href="">팔로우 271</a></div>
                                      </div>
                                  </div>
                              <div class="user_name">${name}</div>`
            $('#upper_right').append(temp_html);
        }
    });
}

😭 메인화면 오른쪽 미니프로필에 사용자 아이디와 이름 나오도록 설정(Jinja 사용)

  • 위와 같은 아이디어로 진행하였다. 이번에는 render_template 기능을 사용하였고, Jinja를 써서 템플릿에 바로 값을 넣어주었다.
def home():
	# 현재 이용자의 컴퓨터에 저장된 cookie 에서 mytoken 을 가져 옴.
	token_receive = request.cookies.get('mytoken')
	try:
		# 암호화되어있는 token의 값을 우리가 사용할 수 있도록 디코딩(암호화 풀기)해줌
		payload = jwt.decode(token_receive, SECRET_KEY, algorithms=['HS256'])
		print(payload)
		user_info = db.user_info.find_one({"insta_id": payload['id']})
		user_id = user_info['insta_id']
		user_name = user_info['name']
		return render_template('index.html', user_name=user_info["name"], user_id=user_info['insta_id'])
<div class="side-name"> <!-- Jinja 사용 -->
                <div>
                    <a href="/mypage"><span style="font-weight: bold">{{ user_id }}</span></a>
                    <br>
                    <span>{{ user_name }}</span>
                </div>
                <div>
                    <a class="side-change" href="#">전환</a>
                </div>

            </div>

😭

profile
https://github.com/nikevapormax

0개의 댓글