서버 점검 안내

dsclub은 서비스의 안정성과 성능 향상을 위해
매일 04시 30분에 정기 점검이 진행됩니다.

점검 시간: 오전 4시 30분 ~ 4시 35분

해당 시간 동안 일시적으로 서비스에 접속이 불가능하오니, 양해 부탁드립니다.

그누보드5 유튜브 영상 표현 스크립트 > 코딩 스토리

그누보드5 유튜브 영상 표현 스크립트

페이지 정보

작성자 profile_image tak2 (115.♡.171.219) 작성일 24-08-19 09:36 조회 225 댓글 0

본문

[code]<script>
// bo_v_con 요소 선택
const boVCon = document.getElementById('bo_v_con');
 
// 유튜브 링크 형식 정의
const youtubeDomains = [
  'youtube.com',
  'youtu.be',
  'www.youtube.com'
];
 
// 정규 표현식 생성
const youtubeRegex = new RegExp(`(https?://)?(${youtubeDomains.join('|')})/(shorts/|watch\\?v=|)([\\w-]+)`, 'g');
 
// bo_v_con의 텍스트를 가져와서 링크를 검색
let textContent = boVCon.innerHTML;
 
// 링크가 발견되면 object 요소를 생성
const matches = textContent.match(youtubeRegex);
if (matches) {
  // 중복 제거를 위한 Set 사용
  const uniqueLinks = Array.from(new Set(matches));
 
  uniqueLinks.forEach(link => {
    let videoId = '';
 
    // 링크에 따라 videoId를 추출
    if (link.includes('youtu.be')) {
      videoId = link.split('/').pop(); // youtu.be 링크에서 videoId 추출
    } else if (link.includes('youtube.com')) {
      const url = new URL(link);
      if (url.pathname.includes('shorts')) {
        videoId = url.pathname.split('/').pop(); // shorts 링크에서 videoId 추출
      } else if (url.searchParams.has('v')) {
        videoId = url.searchParams.get('v'); // watch?v= 링크에서 videoId 추출
      } else {
        videoId = url.pathname.split('/').pop(); // 기본 링크에서 videoId 추출
      }
    }
 
    // videoId가 유효한 경우에만 iframe 요소 생성
    if (videoId) {
      // iframe 요소 생성
      const videoContainer = `<div class="video-container" style="text-align: center;">
                                <iframe width="100%" height="500" src="https://www.youtube.com/embed/${videoId}" allowfullscreen></iframe>
                              </div>`;
 
      // 기존 콘텐츠에서 해당 링크를 비디오 요소로 교체
      const safeLink = link.replace(/[-\/\\^$.*+?()[\]{}|]/g, '\\$&'); // 링크를 안전하게 변환
      textContent = textContent.replace(new RegExp(`(?:<a[^>]*>)?${safeLink}(?:<\/a>)?`, 'g'), videoContainer); // 링크를 videoContainer로 교체
    }
  });
 
  // bo_v_con의 내용을 업데이트
  boVCon.innerHTML = textContent; // 업데이트된 내용을 bovcon에 설정
}
</script>[/code]참고자료: http://1004web.kr/board_ujsG12/96855
뤼튼이 다 떠먹여줬습니다 :)
좋아요1 이 글을 좋아요하셨습니다
url 복사 카카오톡 공유 라인 공유 페이스북 공유 트위터 공유

등록된 댓글이 없습니다.

전체 269건
게시물 검색

접속자집계

오늘
1,313
어제
779
최대
4,271
전체
290,778