模板引擎語法-變量

模板引擎語法-變量

文章目錄

  • 模板引擎語法-變量
    • (一)在Django框架模板中使用變量的代碼實例
    • (二)在Django框架模板中使用變量對象屬性的代碼實例
    • (三)在Django框架模板中使用變量顯示列表

(一)在Django框架模板中使用變量的代碼實例

1.創建項目

cd E:\Python\
django-admin.exe startproject TmplSite

2.在編程工具中打開此項目。

3.創建應用

django-admin.exe startapp gramapp

4.定義應用的視圖文件

文件路徑【TmplSite/gramapp/views.py】

from django.http import HttpResponse
from django.shortcuts import render
from django.template import loader# Create your views here.def index(request):return HttpResponse("Hello, Django! You're at the gramapp index.")def grammar(request):context = {}context['title'] = "Django Template Grammar"context['gram'] = "grammar"template = loader.get_template('gramapp/grammar.html')return HttpResponse(template.render(context, request))

【代碼分析】

代碼分析
context[‘title’] = "Django Template Grammar在變量context中添加了第一個屬性title,并進行了賦值
context[‘gram’] = “grammar”在變量context中添加了第二個屬性grm,并進行了賦值
template = loader.get_template(‘gramapp/grammar.html’)調用get_template()函數加載html模板,并保存在模板對象template中
return HttpResponse(template.render(context, request))通過模板對象template調用了render()函數,將上下文對象context傳遞到html模板grammar.html中進行渲染

5.定義HTML模板的代碼實例

文件路徑【gramapp/templates/gramapp/grammar.html】

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><link rel="stylesheet" type="text/css" href="/static/css/mystyle.css"/><title>{{ title }}</title>
</head>
<body><p class="middle">Hello, this is a <b>{{ gram }}</b> page!
</p></body>
</html>

【代碼分析】

代碼分析
{{ title }}通過雙花括號({{}})引用了views.py中定義的第一個屬性{{title}}
Hello, this is a {{ gram }} page!通過雙花括號({{}})引用了views.py中定義的第二個屬性{{gram}}

6.定義路由文件

文件路徑【TmplSite/gramapp/urls.py】

from django.urls import path
from . import viewsurlpatterns = [path('', views.index, name='index'),path('gram/', views.grammar, name='grammar'),
]

文件路徑【TmplSite/TmplSite/urls.py】

from django.contrib import admin
from django.urls import include, pathurlpatterns = [path('gramapp/', include('gramapp.urls')),path('admin/', admin.site.urls),
]

7.定義項目根目錄的settings.py文件

INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','gramapp.apps.GramappConfig',		# 新增應用
]

8.打開FireFox瀏覽器訪問

【http://localhost:8000/gramapp/】

在這里插入圖片描述

【http://localhost:8000/gramapp/gram/】

在這里插入圖片描述

(二)在Django框架模板中使用變量對象屬性的代碼實例

1.編輯視圖文件

文件路徑【TmplSite/gramapp/views.py】

from django.http import HttpResponse
from django.shortcuts import render
from django.template import loader# Create your views here.def index(request):return HttpResponse("Hello, Django! You're at the gramapp index.")def grammar(request):context = {}context['title'] = "Django Template Grammar"context['gram'] = "grammar"context['author'] = {'first_name': 'King', 'last_name': 'Wang'}		# 新增此行template = loader.get_template('gramapp/grammar.html')return HttpResponse(template.render(context, request))

【代碼分析】

代碼分析
context[‘author’] = {‘first_name’: ‘King’, ‘last_name’: ‘Wang’}在變量context中追加了一個屬性author,并賦值為一個字典類型

2.編輯HTML模板

文件路徑【TmplSite/gramapp/templates/grammar.html】

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><link rel="stylesheet" type="text/css" href="/static/css/mystyle.css"/><title>{{ title }}</title>
</head>
<body><p>Hello, this is a <b>{{ gram }}</b> page!
</p>
<p>Author: <b>{{ author.first_name }} {{ author.last_name }}</b>
</p></body>
</html>

【代碼分析】

代碼分析
Author: {{ author.first_name }} {{ author.last_name }}通過.引用視圖中定義的兩個屬性

3.打開FireFox瀏覽器訪問

【http://localhost:8000/gramapp/gram/】

在這里插入圖片描述

(三)在Django框架模板中使用變量顯示列表

1.編輯視圖文件

文件路徑【TmplSite/gramapp/views.py】

from django.http import HttpResponse
from django.shortcuts import render
from django.template import loader# Create your views here.def index(request):return HttpResponse("Hello, Django! You're at the gramapp index.")def grammar(request):context = {}context['title'] = "Django Template Grammar"context['gram'] = "grammar"context['author'] = {'first_name': 'King', 'last_name': 'Wang'}context['languages'] = ['Python', 'Django', 'Jinja2']	# 新增此行template = loader.get_template('gramapp/grammar.html')return HttpResponse(template.render(context, request))

【代碼分析】

代碼分析
context[‘languages’] = [‘Python’, ‘Django’, ‘Jinja2’]在變量context中追加了一個屬性languages,并賦值為列表類型

2.編輯HTML模板

文件路徑【TmplSite/gramapp/templates/grammar.html】

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><link rel="stylesheet" type="text/css" href="/static/css/mystyle.css"/><title>{{ title }}</title>
</head>
<body><p>Hello, this is a <b>{{ gram }}</b> page!
</p>
<p>Author: <b>{{ author.first_name }} {{ author.last_name }}</b>
</p>
<p>Languages:<br><ul>{% for lang in languages %}<li>{{ lang }}</li>{% endfor %}</ul>
</p>
</body>
</html>

【代碼分析】

代碼分析


Languages:


  • {% for lang in languages %}
    {{ lang }}
    {% endfor %}

定義了一個
  • 列表元素;通過在模板中嵌套for語句,遍歷了Languages屬性;通過在元素中插入列表項“{{lang}}”,將Languages屬性的每一項值顯示在頁面中

3.打開FireFox瀏覽器訪問

【http://localhost:8000/gramapp/gram/】

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/901329.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/901329.shtml
英文地址,請注明出處:http://en.pswp.cn/news/901329.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

AUTO-RAG: AUTONOMOUS RETRIEVAL-AUGMENTED GENERATION FOR LARGE LANGUAGE MODELS

Auto-RAG&#xff1a;用于大型語言模型的自主檢索增強生成 單位&#xff1a;中科院計算所 代碼&#xff1a; https://github.com/ictnlp/Auto-RAG 擬解決問題&#xff1a;通過手動構建規則或者few-shot prompting產生的額外推理開銷。 貢獻&#xff1a;提出一種以LLM決策為中…

Python 基礎語法匯總

Python 語法 │ ├── 基本結構 │ ├── 語句&#xff08;Statements&#xff09; │ │ ├── 表達式語句&#xff08;如賦值、算術運算&#xff09; │ │ ├── 控制流語句&#xff08;if, for, while&#xff09; │ │ ├── 定義語句&#xff08;def…

一文詳解ffmpeg環境搭建:Ubuntu系統ffmpeg配置nvidia硬件加速

在Ubuntu系統下安裝FFmpeg有多種方式,其中最常用的是通過apt-get命令和源碼編譯安裝。本文將分別介紹這兩種方式,并提供安裝過程。 一、apt-get安裝 使用apt-get命令安裝FFmpeg是最簡單快捷的方式,只需要在終端中輸入以下命令即可: # 更新軟件包列表 sudo apt-get updat…

Android 14 、15動態申請讀寫權限實現 (Java)

在 Android 14、15 中&#xff0c;Google 進一步優化了存儲權限系統&#xff0c;特別是寫權限的管理。以下是完整的 Java 實現方案&#xff1a; 1. AndroidManifest.xml 聲明權限 <!-- Android 14 存儲權限 --> <uses-permission android:name"android.permiss…

小剛說C語言刷題——第23講 字符數組

前面&#xff0c;我們學習了一維數組和二維數組的概念。今天我們學習一種特殊的數組&#xff0c;字符數組。 1.字符數組的概念 字符數組就是指元素類型為字符的數組。字符數組是用來存放字符序列或者字符串的。 2.字符數組的定義及語法 char ch[5]; 3.字符數組的初始化及賦…

用AI生成系統架構圖

DeepSeek+Drawio+SVG繪制架構圖-找到一種真正可行實用的方法和思路 1、使用DeepSeek生成SVG文件,導入drawio工具的方法 ?? 問題根源分析 錯誤現象: ? 導入時報錯包含 data:image/SVG;base64 和 %20 等 URL 編碼字符 ? 代碼被錯誤轉換為 Base64 格式(適用于網頁嵌入,但…

免費干凈!付費軟件的平替款!

今天給大家分享一款超棒的電腦錄屏軟件&#xff0c;簡直不要太好用&#xff01;它的界面特別干凈&#xff0c;沒有一點兒廣告&#xff0c;看起來特別清爽。 電腦錄屏 無廣告的錄屏軟件 這個軟件超方便&#xff0c;根本不用安裝&#xff0c;打開就能直接用。 它功能也很強大&am…

【XCP實戰】AUTOSAR架構下XCP從0到1開發配置實踐

目錄 前言 正文 1.CAN功能開發 1.1 DBC的制作及導入 1.2 CanTrcv模塊配置 1.3 Can Controller模塊配置 1.4 CanIf模塊配置 2.XCP模塊集成配置配置 2.1.XCP模塊配置 2.2.XCP模塊的Task Mapping 2.3.XCP模塊的初始化 3.在鏈接文件中定義標定段 4.編寫標定相關的測試…

Vitis: 使用自定義IP時 Makefile錯誤 導致編譯報錯

參考文章: 【小梅哥FPGA】 Vitis開發中自定義IP的Makefile路徑問題解決方案 Vitis IDE自定義IP Makefile錯誤&#xff08;arm-xilinx-eabi-gcc.exe: error: *.c: Invalid argument&#xff09;解決方法 Vitis 使用自定義IP時: Makefile 文件里的語句是需要修改的&#xff0c;…

Python中NumPy的統計運算

在數據分析和科學計算領域&#xff0c;Python憑借其豐富的庫生態系統成為首選工具之一&#xff0c;而NumPy作為Python數值計算的核心庫&#xff0c;憑借其高效的數組操作和強大的統計運算功能&#xff0c;廣泛應用于機器學習、信號處理、統計分析等場景。本文將系統介紹NumPy在…

C語言程序環境和預處理詳解

本章重點&#xff1a; 程序的翻譯環境 程序的執行環境 詳解&#xff1a;C語言程序的編譯鏈接 預定義符號介紹 預處理指令 #define 宏和函數的對比 預處理操作符#和##的介紹 命令定義 預處理指令 #include 預處理指令 #undef 條件編譯 程序的翻譯環境和執行環…

智能工廠調度系統設計方案研究報告

一、系統架構設計 1.1 物理部署架構 設備層&#xff1a;部署大量搭載多傳感器陣列的 AGV 智能循跡車&#xff0c;這些傳感器包括激光雷達、視覺相機、超聲波傳感器等&#xff0c;用于感知周圍環境信息&#xff0c;實現自主導航與避障功能&#xff1b;在每個工序節點處設置 RF…

全新突破 | 更全面 · 更安全 · 更靈活

xFile 高可用存儲網關 2.0 重磅推出&#xff0c;新增多空間隔離功能從根源上防止數據沖突&#xff0c;保障各業務數據的安全性與獨立性。同時支持 NFS、CIFS、FTP 等多種主流文件協議&#xff0c;無需繁瑣的數據拷貝轉換&#xff0c;即可與現有系統無縫對接&#xff0c;降低集成…

C# js 判斷table中tr否存在相同的值

html 中如&#xff1a; 實現&#xff1a;table數據表格中&#xff0c;點擊刪除按鈕時&#xff0c;驗證相同子訂單號條數是否大于1&#xff0c;大于允許刪除。保證數據表格中只有唯一的一條子訂單號數據。 <table style"width: 100%; background-color: #fff;" ce…

操作系統基礎:07 我們的任務

課程回顧與后續規劃 上節課我們探討了操作系統的歷史。了解歷史能讓我們明智&#xff0c;從操作系統的發展歷程中&#xff0c;我們總結出兩個核心的里程碑式圖像&#xff1a;多進程&#xff08;多任務切換&#xff09;圖像和文件操作圖像 。Unix和Windows等系統的成功&#xf…

16.【.NET 8 實戰--孢子記賬--從單體到微服務--轉向微服務】--單體轉微服務--微服務的部署與運維

部署與運維是微服務架構成功實施的關鍵環節。一個良好的部署與運維體系能夠保障微服務的高可用性、可擴展性和可靠性。在這一階段&#xff0c;重點包括微服務的容器化與編排、API 網關的實現以及日志與監控體系的建設。 一、容器化與編排 1.1 使用 Docker 容器化微服務 容器…

MCP基礎學習計劃詳細總結

MCP基礎學習計劃詳細總結 1.MCP概述與基礎 ? MCP&#xff08;Model Context Protocol&#xff09;&#xff1a;由Anthropic公司于2024年11月推出&#xff0c;旨在實現大型語言模型&#xff08;LLM&#xff09;與外部數據源和工具的無縫集成。 ? 核心功能&#xff1a; ? 資…

NoSQL入門指南:Redis與MongoDB的Java實戰

一、為什么需要NoSQL&#xff1f; 在傳統SQL數據庫中&#xff0c;數據必須嚴格遵循預定義的表結構&#xff0c;就像把所有物品整齊擺放在固定尺寸的貨架上。而NoSQL&#xff08;Not Only SQL&#xff09;數據庫則像一個靈活的儲物間&#xff0c;允許存儲各種類型的數據&#x…

Java 列表初始化全解析:7種方式詳解與最佳實踐

文章目錄 **引言****1. 傳統逐個添加元素****特點****注意事項** **2. Arrays.asList() 構造函數****特點****注意事項** **3. 雙括號初始化&#xff08;匿名內部類&#xff09;****特點****注意事項** **4. Java 9 List.of()&#xff08;不可變列表&#xff09;****特點****注…

最大公約數和最小倍數 java

在Java中&#xff0c;計算兩個數的最大公約數&#xff08;Greatest Common Divisor, GCD&#xff09;和最小公倍數&#xff08;Least Common Multiple, LCM&#xff09;是常見的編程問題。以下是具體的實現方法和代碼示例。 --- ### **1. 最大公約數 (GCD)** 最大公約數是指…