gpt4 book ai didi

javascript - SilverStripe 3.3 - 添加 CMS 字段作为 JavaScript 变量

转载 作者:行者123 更新时间:2023-11-29 17:59:44 26 4
gpt4 key购买 nike

我正在为 SilverStripe 项目尝试一些不同的方法:我需要找到一种方法来获取 CMS 中的字段并将它们放入 JavaScript 变量中以便在 JavaScript 文件中使用。

首先,我在 Page.php 中有一个 Header CMS 字段:

private static $db = array(
'Header' => 'HTMLText'
);

public function getCMSFields() {
$fields = parent::getCMSFields();

$fields->addFieldToTab('Root.Main', new HTMLEditorField('Header', 'Header'));

return $fields;
}

我想在 JavaScript 文件中引用该字段作为变量:

       {
id: 'Text-Intro',
type: 'text',
rect: ['251px', '250px','641px','71px','auto', 'auto'],
text: [Header variable needs to go here],
align: "left",
font: ['Arial, Helvetica, sans-serif', 25, "rgba(0,0,0,1.00)", "500", "none", "normal"]
},

我尝试使用 Requirements::javascriptTemplate() 函数,但在 detail-page_edge.js 文件中无法识别该变量:

public function init() {
parent::init();

Requirements::javascriptTemplate('/themes/simple/javascript/detail-page_edge.js', array(
'Header' => $this->Header
));
}

一定是少了什么,或者这只是过时了?我以前从未在 SilverStripe 中尝试过这个。不过,考虑到这个项目的设置方式,我别无选择。

最佳答案

您可以使用 SilverStripe 模板语法进行简单的变量替换。所以你的 JS 文件应该是:

// ... plain JS code
text: '$Header',
// ... more JS code

请注意,您不能使用更复杂的模板语法,例如 <% loop … %><% if … %> , 作为 javascriptTemplate只会做变量替换。

如果您需要完整的模板功能,您可以渲染 .ss模板文件到字符串并用Requirements::customScript输出.我不认为你应该这样做......即使通过 javascriptTemplate 处理 JS 文件似乎关闭。我宁愿在您的常规标记(例如 .ss 模板)中使用 HTML 数据属性,并以某种方式编写 JavaScript,使其获取所需的属性并在标记的基础上构建。

另外:确保您的文件路径是正确的。而不是写绝对路径:

'/themes/simple/javascript/detail-page_edge.js'

我建议您使用以下内容:

$this->ThemeDir() . '/javascript/detail-page_edge.js'

关于javascript - SilverStripe 3.3 - 添加 CMS 字段作为 JavaScript 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35848089/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com