请考虑以下代码:
$xml = <<<XML
<root>
<region id='thisRegion'></region>
<region id='thatRegion'></region>
</root>
XML;
Run Code Online (Sandbox Code Playgroud)
$partials['thisRegion'] = "<p>Here's this region</p>";
$partials['thatRegion'] = "<p>Here's that region</p>";
$DOM = new DOMDocument;
$DOM->loadXML($xml);
$regions = $DOM->getElementsByTagname('region');
foreach( $regions as $region )
{
$id = $region->getAttribute('id');
$partial = $DOM->createDocumentFragment();
$partial->appendXML( $partials[$id] );
$region->parentNode->replaceChild($partial, $region);
}
echo $DOM->saveXML();
Run Code Online (Sandbox Code Playgroud)
输出是:
<root>
<p>Here's this region</p>
<region id="thatRegion"/>
</root>
Run Code Online (Sandbox Code Playgroud)
我不能为我的生活弄清楚为什么所有的区域标签都没有被替换.这是我的项目中的一个问题,起初我认为它并没有替换我在loadXML之后附加的元素,但是通过一些实验,我无法在这里缩小模式.
我希望代码更正,以允许我用给定的元素节点替换DOMDocument中的所有标签.如果我没有找到它,我也不介意任何输入更有效/实用的方法来执行它.
提前致谢!
[编辑] PHP 5.3.13
我正在使用实际上是从文档复制而来的最基本的烧瓶应用程序,并且收到了一个非常烦人的错误。我已经能够找到它,但不知道如何解决。我知道在实现flask-security时会出现问题,但错误来自sqlalchemy内部。有什么建议吗?
from flask import Flask
from flask.ext.sqlalchemy import SQLAlchemy
import logging
app = Flask(__name__)
app.config['DEBUG'] = True
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///:memory:' #
db = SQLAlchemy(app)
roles_users = db.Table('roles_users',
db.Column('user_id', db.Integer(), db.ForeignKey('user.id')),
db.Column('role_id', db.Integer(), db.ForeignKey('role.id')))
class Role(db.Model):
id = db.Column(db.Integer(), primary_key=True)
name = db.Column(db.String(80), unique=True)
description = db.Column(db.String(255))
def __init__(self, name, desc):
self.name = name
self.description = desc
def __repr__(self):
return '<Role: {}>'.format(str(self.name))
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(255), unique=True)
password = db.Column(db.String(255))
roles = db.relationship('Role', secondary=roles_users,
backref=db.backref('users', lazy='dynamic')) …Run Code Online (Sandbox Code Playgroud)