레이더차트 적용 질문

레이더차트 적용 질문

QA

레이더차트 적용 질문

답변 4

본문

https://apexcharts.com/javascript-chart-demos/radar-charts/basic/

이 부분을 여분필드 5~10번을 사용해서 적용시키려고 하는데요.

 

 

https://sir.kr/qa/378948

 

이글을 참고해서 적용해봤는데 View에서 불러오질 못하더라구요. 해결 방법이 있으면 답변 부탁드립니다

 


<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Basic Radar</title>
    <link href="../../assets/styles.css" rel="stylesheet" />
    <style>
      
        #chart {
      max-width: 450px;
      margin: 35px auto;
    }
      
    </style>
    <script>
      window.Promise ||
        document.write(
          '<script src="https://cdn.jsdelivr.net/npm/promise-polyfill@8/dist/polyfill.min.js"><\/script>'
        )
      window.Promise ||
        document.write(
          '<script src="https://cdn.jsdelivr.net/npm/eligrey-classlist-js-polyfill@1.2.20171210/classList.min.js"><\/script>'
        )
      window.Promise ||
        document.write(
          '<script src="https://cdn.jsdelivr.net/npm/findindex_polyfill_mdn"><\/script>'
        )
    </script>
    
    <script src="https://cdn.jsdelivr.net/npm/react@16.12/umd/react.production.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/react-dom@16.12/umd/react-dom.production.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/prop-types@15.7.2/prop-types.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.34/browser.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/apexcharts"></script>
    <script src="https://cdn.jsdelivr.net/npm/react-apexcharts@1.3.6/dist/react-apexcharts.iife.min.js"></script>
    
    <script>
      // Replace Math.random() with a pseudo-random number generator to get reproducible results in e2e tests
      // Based on https://gist.github.com/blixt/f17b47c62508be59987b
      var _seed = 42;
      Math.random = function() {
        _seed = _seed * 16807 % 2147483647;
        return (_seed - 1) / 2147483646;
      };
    </script>
    
  </head>
  <body>
    
    <div id="app"></div>
    <div id="html">
      <div id="chart">
  <ReactApexChart options={this.state.options} series={this.state.series} type="radar" height={350} />
</div>
    </div>
    <script type="text/babel">
      class ApexChart extends React.Component {
        constructor(props) {
          super(props);
          this.state = {
          
            series: [{
              name: 'Series 1',
              data: [<?php echo $wr_5 ?>, <?php echo $wr_6 ?>, <?php echo $wr_7 ?>, <?php echo $wr_8 ?>, <?php echo $wr_9 ?>, <?php echo $wr_10 ?>],
            }],
            options: {
              chart: {
                height: 350,
                type: 'radar',
              },
              title: {
                text: 'Basic Radar Chart'
              },
              xaxis: {
                categories: ['January', 'February', 'March', 'April', 'May', 'June']
              }
            },
          
          
          };
        }
      
        render() {
          return (
            <div>
              <div id="chart">
                <ReactApexChart options={this.state.options} series={this.state.series} type="radar" height={350} />
              </div>
              <div id="html-dist"></div>
            </div>
          );
        }
      }
      const domContainer = document.querySelector('#app');
      ReactDOM.render(React.createElement(ApexChart), domContainer);
    </script>
    
  </body>
</html>

 

이 질문에 댓글 쓰기 :

답변 4

디버깅 해서 확인해보니


data: [<?php echo $wr_5 ?>, <?php echo $wr_6 ?>, <?php echo $wr_7 ?>, <?php echo $wr_8 ?>, <?php echo $wr_9 ?>, <?php echo $wr_10 ?>],

의 값이 셋팅이 안되서 발생하는 문제였습니다.

 

아래 수정된사항은 정상적으로 잘되오니 비교 참고 해보시면 도움이 되실듯합니다.


<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Basic Radar</title>
    <link href="../../assets/styles.css" rel="stylesheet" />
    <style>
      
        #chart {
      max-width: 450px;
      margin: 35px auto;
    }
      
    </style>
    <script>
      window.Promise ||
        document.write(
          '<script src="https://cdn.jsdelivr.net/npm/promise-polyfill@8/dist/polyfill.min.js"><\/script>'
        )
      window.Promise ||
        document.write(
          '<script src="https://cdn.jsdelivr.net/npm/eligrey-classlist-js-polyfill@1.2.20171210/classList.min.js"><\/script>'
        )
      window.Promise ||
        document.write(
          '<script src="https://cdn.jsdelivr.net/npm/findindex_polyfill_mdn"><\/script>'
        )
    </script>
    
    <script src="https://cdn.jsdelivr.net/npm/react@16.12/umd/react.production.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/react-dom@16.12/umd/react-dom.production.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/prop-types@15.7.2/prop-types.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-core/5.8.34/browser.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/apexcharts"></script>
    <script src="https://cdn.jsdelivr.net/npm/react-apexcharts@1.3.6/dist/react-apexcharts.iife.min.js"></script>
    
    <script>
      // Replace Math.random() with a pseudo-random number generator to get reproducible results in e2e tests
      // Based on https://gist.github.com/blixt/f17b47c62508be59987b
      var _seed = 42;
      Math.random = function() {
        _seed = _seed * 16807 % 2147483647;
        return (_seed - 1) / 2147483646;
      };
    </script>
    
  </head>
  <body>
    
    <div id="app"></div>
    <div id="html">
      <div id="chart">
  <ReactApexChart options={this.state.options} series={this.state.series} type="radar" height={350} />
</div>
    </div>
    <script type="text/babel">
      var options = {
          series: [{
          name: 'Series 1',
          data: [80, 50, 30, 40, 100, 20],
        }],
          chart: {
          height: 350,
          type: 'radar',
        },
        title: {
          text: 'Basic Radar Chart'
        },
        xaxis: {
          categories: ['January', 'February', 'March', 'April', 'May', 'June']
        }
        };
        var chart = new ApexCharts(document.querySelector("#chart"), options);
        chart.render();
        
      class ApexChart extends React.Component {
        constructor(props) {
          super(props);
          this.state = {
          
            series: [{
              name: 'Series 1',
              data: [80, 50, 30, 40, 100, 20],
            }],
            options: {
              chart: {
                height: 350,
                type: 'radar',
              },
              title: {
                text: 'Basic Radar Chart'
              },
              xaxis: {
                categories: ['January', 'February', 'March', 'April', 'May', 'June']
              }
            },
          
          
          };
        }
      
        render() {
          return (
            <div>
              <div id="chart">
                <ReactApexChart options={this.state.options} series={this.state.series} type="radar" height={350} />
              </div>
              <div id="html-dist"></div>
            </div>
          );
        }
      }
      const domContainer = document.querySelector('#app');
      ReactDOM.render(React.createElement(ApexChart), domContainer);
    </script>
    
  </body>
</html>

 

위에서 select 하여 fatch한 부분을 확인해보시면 될꺼 같습니다.

data: [<?php echo $wr_5 ?>, <?php echo $wr_6 ?>, <?php echo $wr_7 ?>, <?php echo $wr_8 ?>, <?php echo $wr_9 ?>, <?php echo $wr_10 ?>],

감사합니다 정상적으로 불러와지는데  위 부분에 여분필드에 입력된 숫자 값으로 세팅하려면 어떻게 해야할까요?

$wr_5대신에 $view['wr_5'] 이런식으로 넣어보세요. 다른 변수도 마찬가지요.

우선 wr_5~wr_10 까지 최상단에 값을 제대로 불러오는지 여부 파악하시고..

조건으로 값이 없을 경우 0으로 향하게 해버리신 뒤에 자바스크립트를 확인하시면 될것같은데요...

여분필드 값은 제대로 불러와집니다.ㅠ


data: [80, 50, 30, 40, 100, 20],


여기에 80, 50, 30, 40, 100, 20 을 wr_5~10번 을 불러와야하는데


data: [<?php echo $view['wr_5'] ?>, <?php echo $view['wr_6'] ?>, <?php echo $view['wr_7'] ?>, <?php echo $view['wr_8'] ?>, <?php echo $view['wr_9'] ?>, <?php echo $view['wr_10'] ?>],


이렇게 하면 값을 못불러옵니다..ㅠ 저기에 어떤 걸 입력해야 여분필드를 불러오는지 알고싶습니다..ㅠ

여분필드 값을 추출해오는 쿼리가 질문의 화일에는 없는데 이 화일을 호출하는 주소나 링크가 어떻게 되는지 알아야 진단 가능합니다

답변을 작성하시기 전에 로그인 해주세요.
QA 내용 검색
질문등록
전체 60,954
© SIRSOFT
현재 페이지 제일 처음으로