1. repository 만들기
2. Git Bash 로 push 하기
- 아래 명령어를 차례로 입력
$ cd Local Project Path
$ git init
$ git add .
$ git commit -m "first commit"
$ git remote add origin repositoryURL
$ git push -f orign master
1. repository 만들기
2. Git Bash 로 push 하기
- 아래 명령어를 차례로 입력
$ cd Local Project Path
$ git init
$ git add .
$ git commit -m "first commit"
$ git remote add origin repositoryURL
$ git push -f orign master
이전글
Javascript로 GA 데이터 뽑아오기[1] : https://aljshal.tistory.com/29?category=743241
Javascript로 GA 데이터 뽑아오기[2] : https://aljshal.tistory.com/30?category=743241
위에서 뽑아낸 데이터를 차트로 보고자 하여, 'morris.js' 를 사용하였다.
<!-- morris --> <link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/morris.js/0.5.1/morris.css"> <script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/raphael/2.1.0/raphael-min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/morris.js/0.5.1/morris.min.js"></script>
<div id="myfirstchart"></div> <script> var gaArr = { "test1": "ga:123", "test2": "ga:456", "test3": "ga:789" }; <!-- 중략 - Javascript로 GA 데이터 뽑아오기[1] 참조 --> function handleProfiles(response) { // Handles the response from the profiles list method. if (response.result.items && response.result.items.length) { // Get the first View (Profile) ID. var firstProfileId = response.result.items[0].id; // Query the Core Reporting API. //queryCoreReportingApi(firstProfileId); $.each(gaArr, function (key, value) { query_ga(key, value); }); } else { console.log('No views (profiles) found for this user.'); } } function query_ga(key, value) { gapi.client.analytics.data.ga.get({ 'ids': value, 'start-date': '2016-01-01', 'end-date': '2019-03-24', 'metrics': 'ga:sessions', 'dimensions': 'ga:yearMonth', 'sort': 'ga:yearMonth' }) .then(function (response) { // 리스트 생성 var list = new Array(); $.each(response.result.rows, function (i, j) { var data = new Object(); data.key = j[0]; data.value = j[1]; list.push(data); }); // String 형태로 변환 var jsonData = JSON.stringify(list); // 차트 출력 if ($("#myfirstchart-" + key).length == 0) $("#myfirstchart").append("<h3>" + key + "</h3><div id='myfirstchart-" + key + "' style='height: 200px;'></div>"); var chart = new Morris.Line({ element: 'myfirstchart-' + key, data: list, xkey: ['key'], ykeys: ['value'], labels: ['Value'], parseTime: false, }); }) .then(null, function (err) { console.log(err); }); } // Add an event listener to the 'auth-button'. document.getElementById('auth-button').addEventListener('click', authorize); </script> <script src="https://apis.google.com/js/client.js?onload=authorize"></script>
출력화면
Javascript로 GA 데이터 뽑아오기[2] - 여러 사이트 (0) | 2019.03.26 |
---|---|
Javascript로 GA 데이터 뽑아오기[1] (1) | 2019.03.26 |
css, js 브라우저 캐시(유저가 캐시 초기화 하지 않아도 적용) (0) | 2018.07.17 |
이전글 - Javascript로 GA 데이터 뽑아오기[1] : https://aljshal.tistory.com/29?category=743241
여러 사이트를 관리하고 있다면, 아래와 같이 배열을 이용하여 여러번 호출 하여 출력 하면 된다.
단, 사이트의 ids를 알아야 함 - ( https://ga-dev-tools.appspot.com/query-explorer/ 참고 )
출력화면
Javascript로 GA 데이터 뽑아오기[3] - 차트로 만들기 (0) | 2019.03.26 |
---|---|
Javascript로 GA 데이터 뽑아오기[1] (1) | 2019.03.26 |
css, js 브라우저 캐시(유저가 캐시 초기화 하지 않아도 적용) (0) | 2018.07.17 |
Google에서는 Open API를 제공하여 Google Analytics의 통계를 외부 페이지에 출력 할 수 있다.
단, 사전에 Google APIs에서 사용자 인증 정보를 등록하여 CLIENT_ID 를 알고 있어야 한다.
(이 부분은 다른 사이트를 구글링 하길 바란다.)
<button id="auth-button" hidden>Authorize</button> <h1>Hello Analytics</h1> <textarea cols="80" rows="20" id="query-output"></textarea> <script> // Replace with your client ID from the developer console. var CLIENT_ID = '[CLIENT_ID]'; // Set authorized scope. var SCOPES = ['https://www.googleapis.com/auth/analytics.readonly']; function authorize(event) { // Handles the authorization flow. // `immediate` should be false when invoked from the button click. var useImmdiate = event ? false : true; var authData = { client_id: CLIENT_ID, scope: SCOPES, immediate: useImmdiate }; gapi.auth.authorize(authData, function(response) { var authButton = document.getElementById('auth-button'); if (response.error) { authButton.hidden = false; } else { authButton.hidden = true; queryAccounts(); } }); } function queryAccounts() { // Load the Google Analytics client library. gapi.client.load('analytics', 'v3').then(function() { // Get a list of all Google Analytics accounts for this user gapi.client.analytics.management.accounts.list().then(handleAccounts); }); } function handleAccounts(response) { // Handles the response from the accounts list method. if (response.result.items && response.result.items.length) { // Get the first Google Analytics account. var firstAccountId = response.result.items[0].id; // Query for properties. queryProperties(firstAccountId); } else { console.log('No accounts found for this user.'); } } function queryProperties(accountId) { // Get a list of all the properties for the account. gapi.client.analytics.management.webproperties.list( {'accountId': accountId}) .then(handleProperties) .then(null, function(err) { // Log any errors. console.log(err); }); } function handleProperties(response) { // Handles the response from the webproperties list method. if (response.result.items && response.result.items.length) { // Get the first Google Analytics account var firstAccountId = response.result.items[0].accountId; // Get the first property ID var firstPropertyId = response.result.items[0].id; // Query for Views (Profiles). queryProfiles(firstAccountId, firstPropertyId); } else { console.log('No properties found for this user.'); } } function queryProfiles(accountId, propertyId) { // Get a list of all Views (Profiles) for the first property // of the first Account. gapi.client.analytics.management.profiles.list({ 'accountId': accountId, 'webPropertyId': propertyId }) .then(handleProfiles) .then(null, function(err) { // Log any errors. console.log(err); }); } function handleProfiles(response) { // Handles the response from the profiles list method. if (response.result.items && response.result.items.length) { // Get the first View (Profile) ID. var firstProfileId = response.result.items[0].id; // Query the Core Reporting API. queryCoreReportingApi(firstProfileId); } else { console.log('No views (profiles) found for this user.'); } } function queryCoreReportingApi(profileId) { // Query the Core Reporting API for the number sessions for // the past seven days. gapi.client.analytics.data.ga.get({ 'ids': 'ga:' + profileId, 'start-date': '2019-03-18', 'end-date': '2019-03-24', 'metrics': 'ga:sessions' }) .then(function(response) { var formattedJson = JSON.stringify(response.result, null, 2); document.getElementById('query-output').value = formattedJson; }) .then(null, function(err) { // Log any errors. console.log(err); }); } // Add an event listener to the 'auth-button'. document.getElementById('auth-button').addEventListener('click', authorize); </script> <script src="https://apis.google.com/js/client.js?onload=authorize"></script>
출력화면
Javascript로 GA 데이터 뽑아오기[3] - 차트로 만들기 (0) | 2019.03.26 |
---|---|
Javascript로 GA 데이터 뽑아오기[2] - 여러 사이트 (0) | 2019.03.26 |
css, js 브라우저 캐시(유저가 캐시 초기화 하지 않아도 적용) (0) | 2018.07.17 |
autoplay=0 : 자동 플레이가 안되게 한다.
autoplay=1 : 자동 플레이가 되게 한다.
rel=0 : 관련 동영상을 감춘다.
rel=1 : 관련 동영상이 나타나게 한다.
showsearch=0 : 검색창을 감춘다.
showsearch=1 : 검색창이 나오게 한다.
loop=0 : 1번만 동영상이 플레이 된다.
loop=1 : 계속해서 동영상이 리플레이 된다.
start=0 : 첫부분에서 시작한다. (동영상 시작 시간을 지정해줄 수 있다)
start=30 : 30초 부분 부터 시작한다.
showinfo=0 : 타이틀을 감춘다.
showinfo=1 : 타이틀을 나오게 한다.
ex)
<iframe allowscriptaccess="always" allowfullscreen="" src="https://www.youtube.com/embed/HtQ7BQvnfyg?autoplay=1&rel=0&showsearch=0&loop=1&showinfo=0&enablejsapi=1" width="100%" height="855" frameborder="0"></iframe>