>웹 프론트엔드 >JS 튜토리얼 >Jinja2를 사용하여 템플릿에서 Flask의 데이터를 JavaScript로 전달하는 방법은 무엇입니까?

Jinja2를 사용하여 템플릿에서 Flask의 데이터를 JavaScript로 전달하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-27 21:58:011206검색

How to Pass Data from Flask to JavaScript in Templates Using Jinja2?

Flask에서 템플릿의 JavaScript로 데이터 전달

Flask 애플리케이션의 API에서 데이터를 가져올 때 다음을 전달해야 할 수 있습니다. 해당 정보를 해당 템플릿의 JavaScript에 전달합니다. 이 기사에서는 Jinja2 템플릿의 강력한 기능을 활용하여 이를 달성하는 방법을 살펴봅니다.

Flask에서 render_template 함수를 사용하면 변수를 HTML 템플릿에 전달할 수 있습니다. 그러나 이러한 변수를 JavaScript에서 사용할 수 있도록 하려면 추가 단계가 필요합니다.

Flask에서 사용하는 템플릿 엔진인 Jinja2는 템플릿 내에 Python 표현식을 포함할 수 있는 구문을 제공합니다. 이는 JavaScript 스크립트 내를 포함하여 템플릿의 어느 곳에서나 {{ 변수 }}를 사용할 수 있음을 의미합니다.

예를 들어 API에서 좌표를 검색하는 다음 Flask 경로를 고려해 보세요.

<code class="python">@app.route('/')
def get_data():
    events = api.call(get_event, arg0, arg1)
    geocode = event['latitude'], event['longitude']
    return render_template('get_data.html', geocode=geocode)</code>

해당 템플릿에서 다음과 같이 geocode 변수를 JavaScript에 전달할 수 있습니다.

<code class="html"><script>
var someJavaScriptVar = '{{ geocode[1] }}';
</script></code>

이를 통해 JavaScript 코드에서 geocode[1]의 값에 someJavaScriptVar로 액세스할 수 있습니다.

또는 지오코드 변수를 배열로 전달하기 위해 템플릿에서 배열 정의를 생성할 수 있습니다.

<code class="html"><script>
var myGeocode = ['{{ geocode[0] }}', '{{ geocode[1] }}'];
</script></code>

Jinja2는 루프 및 if 문과 같은 고급 구성도 지원합니다. 복잡한 데이터 구조 생성을 단순화합니다.

또한 tojson 필터를 사용하여 지오코드 튜플을 JSON 문자열로 변환할 수 있으므로 JavaScript에서 사용하기에 더 적합해집니다.

<code class="html"><script>
var myGeocode = {{ geocode | tojson }};
</script></code>

이러한 기술을 통해 개발자는 Flask와 JavaScript 간에 데이터를 원활하게 공유하여 대화형의 동적 웹 애플리케이션을 구현할 수 있습니다.

위 내용은 Jinja2를 사용하여 템플릿에서 Flask의 데이터를 JavaScript로 전달하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.